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1 

APPARATUS FOR READING HANDWRITING 

1 
2 

3 FIELD OF THE INVENTION 

4 The present invention relates to computer 

5 input devices generally and more particularly to 

6 handwriting responsive computer input devices. 
7 

8 BACKGROUND OF THE INVENTION 
9 

10 There exists a significant amount of activity 

11 in the field of on-line handwriting recognition. The 

12 prior art current to 1990 is reviewed in "The State of 

13 the Art in On-Line Handwriting Recognition" by Charles 
lk C. Tap.pert et al f IEEE Transactions on Pattern Analysis 

15 and Machine Intelligence, Vol. 12. No. 8 f August, 1990. 

16 Generally speaking, on-line handwriting 

17 analysis is currently employed for two distinct 

18 applications: identity verification and input of 

19 handwritten letters and numbers into a computer. These 

20 two applications have sharply contrasting operational 

21 requirements and goals. Handwriting analysis for 

22 identity verification senses features of handwriting 

23 which are distinct for each individual and thus can be 
2k used to unambiguously identify a given individual. In 

25 contrast, handwriting analysis for alphanumeric input 

26 to a computer seeks to minimize the effect of the very 

27 features which are important for identity verification 

28 and to concentrate on universal handwriting 

29 characteristics which can be associated with given 

30 symbols independently of the individual writer. 

31 Currently existing and proposed systems 

32 providing handwriting analysis for alphanumeric input 

33 to a computer are generally geared towards recognition 

34 of how a symbol looks rather than how it is created. 

35 Accordingly, such systems employ digitizers or graphic 

36 tablets. 

37 Signature verification systems, on the other 

38 hand, attempt to identify biometric characteristics of 
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1 the writer and employ indications such as pressure and 

2 acceleration during writing. 

3 U.S. Patent 4, 3^5. 239 employs pen 
k acceleration for use in a signature verification 

5 system. U.S. Patent 5.05^.088 employs both acceleration 

6 and pressure data characteristics of handwriting for 

7 identity verification. As indicated by the above 

8 patents, pen acceleration is employed for signature 

9 verification because it is a personal feature, 

10 characteristic of each individual. Accordingly, pen 

11 acceleration has not been employed for alphanumeric 

12 input. 

13 U.S. Patent 4,751.7^1 describes pen-type 

14 character 

15 recognition apparatus which employs pen pressure data 

16 exclusively. 
17 

18 
19 
20 
21 
22 

23 
2k 

25 
26 
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3 

1 SUMMARY OF THE INVENTION 

2 

3 The present invention seeks to provide 

4 improved handwriting information input apparatus. 

5 There is thus provided in accordance with a 

6 preferred embodiment of the present invention apparatus 

7 for reading handwriting including apparatus for sensing 

8 features of handwriting of an individual which features 

9 are highly characteristic of the individual but which 

10 also contain information relating to symbols being 

11 written and apparatus, which is configured for the 

12 individual, for providing a non-individual dependent 

13 output indicating the symbols being written in response 

14 to the sensed features. 

15 In accordance with a preferred embodiment of 

16 the present invention «the apparatus for reading 

17 handwriting is contained in a hand-held housing. 

18 Preferably the apparatus for reading handwriting 

19 includes apparatus for wireless communication with a 

20 computer to which it inputs symbol data. 

21 In accordance with a preferred embodiment of 

22 the present invention, the apparatus for reading 

23 handwriting does not require a tablet. Additionally in 
2*4 accordance with a preferred embodiment of the 

25 invention, the apparatus for reading handwriting 

26 communicates with the keyboard input of a computer. 

27 Additionally in accordance with a preferred 

28 embodiment of the present invention there is provided 

29 apparatus for reading handwriting including 

30 personalized hand-held apparatus for sensing 

31 acceleration during handwriting and provfding an output 

32 indication of handwriting content in a non-personalized. 

33 form. 

3^ Further in accordance with a preferred 

35 embodiment of the present invention there is provided 

36 apparatus for reading handwriting including wireless 

37 hand-held apparatus for sensing handwriting and 

38 providing an output indication of the contents thereof. 
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1 Additionally in accordance with a preferred 

2 embodiment of the present invention there is provided 

3 apparatus for reading handwriting including personally 
k trainable hand-held apparatus for sensing motion during 

5 handwriting and providing an output indication of 

6 handwrijting content. 

7 Further in accordance with a preferred 

8 embodiment of the present invention there is provided 

9 apparatus for reading handwriting in real time 

10 comprising a hand held housing, a motion sensor 

11 disposed in the housing, recognizing apparatus disposed 

12 within the hosing and receiving signals from said 

13 motion sensor for sensing a plurality of handwriting 
Ik characteristics and symbol recognizing apparatus 

15 disposed in said housing receiving the outputs of the 

16 plurality of parallel recognizers for providing an 

17 indication of a handwritten symbol. 

18 Additionally in accordance with a preferred 

19 embodiment of the present invention there is provided 

20 apparatus for reading handwriting including hand-held 

21 apparatus for sensing motion during handwriting and 

22 providing an output indication of handwriting content 

23 in a form corresponding to that of a conventional 

24 keyboard. 

25 Further in accordance with a preferred 

26 embodiment of the present invention there is provided 

27 apparatus for reading handwriting including hand-held 

28 apparatus for sensing motion during handwriting and 

29 providing an output indication of handwriting content 

30 in a RS-232 compatible form. 

31 Additionally in accordance with a preferred 

32 embodiment of the present invention there is provided 

33 audio-visual apparatus including apparatus for 

34 providing a human sensible output including information 

35 in at least one of audio and visual form and having as 

36 an input element hand-held apparatus for sensing motion 

37 during handwriting of the type described hereinabove. 

38 Examples of such audio-visual apparatus 
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1 include a video recorder and player, a stereo audio 

2 player and a television. 

3 Further in accordance with a preferred 

4 embodiment of the present invention there is provided 

5 portable information storage and retrieval apparatus 

6 including a portable computer memory and output device 

7 and having as an input element hand-held apparatus for 

8 sensing motion during handwriting of the type described 

9 hereinabove. 

10 Examples of such portable information storage 

11 and retrieval apparatus include a digital watch with 

12 memory, a computerized diary, a computerized dictionary 

13 and electronic telephone book. 

14 Additionally in accordance with a preferred 

15 embodiment of the present invention there is provided 
16. lock apparatus including locking apparatus responsive 

17 to a predetermined electronic input and having as an 

18 input element hand-held apparatus for sensing motion 

19 during handwriting of the type described hereinabove. 

20 Examples of such locking apparatus include 

21 door locks and vehicle door locks and ignitions. 

22 Further in accordance with a preferred 

23 embodiment of the present invention there is provided 
2k magnetic card activated apparatus including apparatus 

25 for reading a magnetic card and having as a 

26 verification input element, hand-held apparatus for 

27 sensing motion during handwriting of the type described 

28 hereinabove. 

29 Examples of such magnetic card activated 

30 apparatus include automatic teller apparatus and point 

31 of sales credit card acceptance units. 

32 Various combinations of the above-mentioned 

33 structural and functional elements alone or in 

34 combination with additional elements, such as, for 

35 example, graphical input capabilities, are also within 

36 the scope of the present invention. 

37 
38 
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1 BRIEF DESCRIPTION OF THE DRAWINGS 

2 The present invention will be understood and 

3 appreciated more fully from the following detailed 

4 description, taken in conjunction with the drawings in 

5 which: 

6 Fig, 1 is a pictorial illustration of a 

7 handwriting reading device constructed and operative in 

8 accordance with a preferred embodiment of the present 

9 invention in an operative environment; 

10 Fig. 2 is a simplified illustration of a 

11 preferred mechanical structure of the handwriting 

12 reading device of the present invention; 

1-3 Fig. 3 is a simplified block diagram 

14 illustration of the handwriting reading device of Figs. 

15 2 and 3; 

16 Fig. 4 is a partially schematic, partially 

17 block diagram illustration of part of the apparatus of 

18 Fig. 3; 

19 Fig. 5 is a block diagram illustration of 

20 part of the apparatus of Fig. 4; and 

21 Figs. 6A and 6B are simplified flow charts 

22 illustrating operation of the handwriting reading 

23 device of Figs. 3 - 5 during handwriting reading. Fig. 

24 6B illustrates the teaching process and Fig. 6B 

25 illustrates the recognition process. 
26 

27 
28 
29 
30 

31 
32 

33 
34 

35 
36 

37 
38 
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1 DETAILED DESCRIPTION OF A- PREFERRED EMBODIMENT 

2 It has been found by the present inventor 

3 that each writer produces conventional alphanumeric 

4 characters from pen strokes selected from a set 

5 containing approximately 12 - 14 pen strokes, which set 

6 is characteristic of each individual . The present 

7 invention employs this realization to provide a 

8 personalizable handwriting input device. Appendix A 

9 contains a detailed exposition of the finding of the 
10 inventor. 

11 

12 Reference is now made to Fig. 1, which 

13 illustrates a handwriting input device 10 constructed 

14 and operative in accordance with a preferred embodiment 

15 of the invention in a typical operating environment 

16 wherein it communicates by wireless communication with 

17 a computer 11, such as a notebook PC having an 

18 associated receiver 12, such as a model RB 1023 RF 

19 receiver, commercially available from RF Monolithics, 

20 Inc. of Dallas, Texas. Receiver 12 may communicate 

21 with computer 11 via the RS 232 port thereof or 

22 alternatively via the keyboard input thereof. 

23 . . 

24 The handwriting input device 10, which is 

25 illustrated in greater detail in Fig. 2, may be used on 

26 any writing surface or alternatively in the absence of 

27 a writing surface and does not require any special pad 

28 or writing substrate. Preferably the handwriting input 

29 device comprises a housing 13 in the general size and 

30 shape of an ordinary pen which is preferably provided 

31 with suitable indentations 14 "for predetermined finger 

32 engagement. 

33 Disposed in housing 13 is an ink reservoir 

34 and output point assembly 16, which may be constructed 

35 and operative in any conventional manner. Alternatively 

36 no ink output may be provided. In accordance with a 

37 preferred embodiment of the present invention there is 

38 disposed in a forward location of the housing 13 an 
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1 accelerome ter 20, preferably operative in- three 

2 dimensions. Preferably the accelerome ter 2G is located 

3 interiorly of indentations 14 . A typical accelerometer 

4 which meets the size and power requirements of the 

5 invention comprises at least two and preferably three 

6 mutually orthogonally mounted Model 3031 accelerome ters 

7 commercially available from EuroSensor of 20 - 24 Kirby 

8 Street, London, England. 

9 Referring additionally to Fig. 3, it is seen 

10 that the output of the accelerometer 20 is supplied via 

11 an operational amplifier 24, such as a model LT1179. 

12 commercially available from Linear Technology 

13 Corporation of Milpitas, California, to a 

14 microcontroller 26, such as an Hitachi H8/536 

15 microcontroller including an A/D converter. 

16 Microcontroller 26 is operative to extract a plurality 

17 of predetermined features of the acceleration sensed by 
18. accelerometer 20. It is a particular feature of the 

19 present invention that a relatively small number of 

20 discrete features derived from sensed acceleration 

21 during handwriting has been found to be sufficient to 

22 map the alphanumeric symbols of a given individual. It 

23 is appreciated that the characteristics of such 

24 features vary from individual to individual and 

25 accordingly, the microcontroller must be personalized 

26 through training in order to select suitable feature 

27 characteristics for a given individual. 
28 

29 A typical catalog of features extracted by 

30 the microcontroller 26 appears in the Tappert et al 

31 reference described hereinabove and is hereby 

32 incorporated by reference and also appears more 

33 explicitly in Appendix B. A preferred listing of 

34 software that provides the functionality of the 

35 microcontroller 26 appears in Appendix C. 

36 The microcontroller 26 provides the 

37 functionality of a bank of parallel recognizers 26. 

38 The parallel recognizers are operative to recognize 
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1 128 different symbols. They may also be operative to 

2 recognizers various graphic symbols. The parallel 

3 recognizers are also personalized by suitable training 

4 which is preferably carried out using the pen 10 and 

5 the computer 11 and involves subsequent downloading to 

6 the pen 12, so as to associate the various alphanumeric 

7 symbols with given acceleration derived features 

8 extracted by the microcontroller 26. 

9 The microcontroller 26 also provides the 
1G functionality of post-processing circuitry and is 

11 operative to select the most probable symbol from among 

12 those recognized by the bank of parallel recognizer and 

13 to encode it in a conventional universal code, such as 
1*1 ASCII, which is not in any way dependent on the 

15 personal handwriting characteristics of a given 

16 individual and which can be readily accepted by 

17 conventional computers. 

18 Preferably, the coded symbol output from 

19 microcontroller 26 is in a form compatible with or 

20 identical to the output conventionally received at the 

21 keyboard input of a conventional computer, such as a 

22 PC. 

23 In accordance with a preferred embodiment of 

24 the present invention, the coded output of 

25 microcontroller 26 is transmitted to computer 11 in a 

26 wireless manner by a wireless transmitter 32, such as 

27 a model MB1003; which is also commercially available 

28 from RF Monolithics, Inc. and which communicates with 

29 receiver 12 (Fig 1). Alternatively any other suitable 

30 IR transmitter or radio transmitter may be utilized. In 

31 such a case, the computer 11 is preferably supplied 

32 with a corresponding receiver which outputs directly to 

33 the keyboard input of the computer or any other 

34 suitable input, such as an RS 232 port.. Alternatively a 

35 non-wireless communication connection may be provided. 

36 A suitable battery 33 is provided to power the 

37 apparatus located within housing 13. 

38 It will be appreciated that the handwriting 
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1 reading apparatus of the present invention is 

2 preferably a hand-held, personalized "pen" which can be 

3 carried by the individual for whom it has been 

4 personalized and used with any computer having suitable 

5 communication facilities. The computer need not be 

6 personalized in any way, inasmuch as all of the 

7 handwriting recognition hardware and software is 

8 resident in the "pen". 

9 Reference is now made to Fig. 4 and Fig. 5 

10 which illustrate portions of the apparatus of Figs. 1 - 

11 3 in differing levels of detail. The accelerometer 20, 

12 as noted above, preferably comprises three separate 

13 accelerometer modules, each including a bridge 

14 containing piezoresis tive elements outputs via 

15 operational amplifier 24 to microcontroller 26 

16 including A/D converter channels 44. As noted above, 

17 the microcontroller 26 provides DSP functionality, 

18 represented by block 45 which is preferably operative 

19 to extract 32 features which are combinations of 

20 components of X-acceleratidn , Y-acceleration and up and 

21 down movements of the pen. 

22 The output of functional block 45 is supplied 

23 to the bank of parallel recognizers 26 which includes a 

24 plurality of fuzzy comparators 46, each of which 

25 receives from reference feature storage facility 47 

26 reference features for a plurality of alphanumeric 

27 symbols in addition to the serial input from DSP 

28 circuitry 24 which contains vectors representing the 

29 extracted features. The outputs of the fuzzy 

30 comparators 46 are supplied to corresponding error 

31 accumulators 48. The outputs of the error accumulators 

32 48 are supplied to a fuzzy associative memory 50 which 

33 receives threshold inputs from a threshold definer 52. 

34 Threshold definer 52 receives data inputs together with 

35 control and timing inputs. 

36 It is appreciated that in accordance with a 

37 preferred embodiment of the invention, the structure of 

38 Figs. . 4 and 5 is embodied in software resident in 
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1 microcontroller 26, as exemplified in Appendix C. 

2 Figs. 6A and 6B are simplified flow charts 

3 illustrating operation of the DSP block 45 (Fig 4). 

4 Fig, 6A illustrates the teaching process and Fig. B 

5 illustrates the recognition process. The DSP block 

6 operates to perform double integration of X and Y 

7 acceleration to obtain not only velocities, but also 

8 positions and travel distances. In addition, non- 

9 linear positive and negative rotations are counted, 

10 located and their length recorded. 

11 Appendix D sets forth an alogorithm for 

12 personalization of the handwriting reading device of 

13 Figs. 3-5. 

1^ The personalized functions are carried out 

15 using the pen 10 and the computer 11. The user 

16 initially writes each alpha-numeric symbol. The symbol 

17 is "read" by the device which determines X, Y and Z 

18 accelerations, and employs the accelerations to extract 

19 the features listed above, in a manner set forth 

20 generally in Fig. 6. Feature recognition is achieved by 

21 recognizing the centroids of the pen-strokes of the 

22 individual writing and by classifying of each character 

23 into 12-16 pen-stroke types. The character is 

24 considered to be a sequence of certain pen-strokes and 

25 is recognized as a fuzzy string over the pen-strokes 

26 alphabet. The fuzzy rules are downloaded to the 

27 microcontroller 26 in the pen 10. 

28 The extracted features are employed to adapt 

29 fuzzy rules. The fuzzy rules are employed in the 

30 operation of a symbol recognizer which provides output 

31 indication of a recognized symbol. 

32 The actual and recognized symbols are 

33 compared to provide a difference indication which is 

34 used to further adapt the fuzzy rules until an 

35 acceptable match between the actual and recognized 

36 symbol is attained. 

37 Additionally in accordance with a preferred 

38 embodiment of the present invention there is provided 
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1 audio-visual apparatus including apparatus for 

2 providing a human sensible output including information 

3 in at least one of audio and visual form and having as 
k an input element hand-held apparatus for sensing motion 

5 during handwriting of the type described hereinabove. 

6 Examples of such audio-visual apparatus 

7 include a video recorder and player, a stereo audio 

8 player and a television. Other home appliances such as 

9 washing machines and cooking apparatus may be operated 

10 along similar principles. 

11 Further in accordance with a preferred 

12 embodiment of the present invention there is provided 

13 portable information storage and retrieval apparatus' 

14 including a portable computer memory and output device 

15 and having as an input element hand-held apparatus for 

16 sensing motion during handwriting of the type described 

17 hereinabove. 

18 Examples of such portable information storage 

19 and retrieval apparatus include a digital watch with 

20 memory, a computerized diary, a computerized dictionary 

21 and electronic telephone book. 

22 Additionally in accordance with a preferred 

23 embodiment of the present invention there is provided 

24 lock apparatus including locking apparatus responsive 

25 to a predetermined electronic input and having as an 

26 input element hand-held apparatus for sensing motion 

27 during handwriting of the type described hereinabove. 

28 Examples of such locking apparatus include 

29 door locks and vehicle door locks and ignitions. 

30 Further in accordance with a preferred 

31 embodiment of the present invention there is provided 

32 magnetic card activated apparatus including apparatus 

33 ?or reading a magnetic card and having as a 

34 verification input element, hand-held apparatus for 

35 sensing motion during handwriting of the type described 

36 hereinabove. 

37 Examples of such magnetic card activated 

38 apparatus include automatic teller apparatus and point 
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1 of sales credit card acceptance units. 

2 It will be appreciated by persons skilled in 

3 the art that the present invention is not limited by 

4 what has been particularly shown and described 

5 hereinabove. Rather the scope of the present invention 

6 is defined only by the claims which follow: 
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APPENDIX A 



What the human brain tells the human 

hand 

A behavioral perspective 

Ehud Bar-On 
E.B. Research & Development Ltd. 
Guttwirth Bldgs, Technion, Haifa 32000, Israel 

September 22 ? 1992 

Abstract 

This study investigates the primitives of motoric patterns of hand 
movement during handwriting. This is referred to as the "language" 
between the "hand and the "brain" t and as such, has its own vocabu- 
lary and syntax. The "vocabulary" is the pen strokes and the syntax is 
how they are combined to pen strokes sequences. The handwriting is 
viewed as a high level cognitive activity of communicating, expressed 
as a complex motor skill and its investigation provides insight into the 
processes of chunking and automaticity. The main finding of this study 
is that pen strokes are specific to an individual writer, and character- 
ize the writer's unique motoric control mechanism. The dynamic data 
of many thousand handwritten characters, produced by many writers, 
had been analyzed. The time domain signals were segmented into dis- 
crete pen strokes units and represented as vectors in a feature space. 
Those vectors were clustered, using a variety of clustering techniques. 
We found that in spite of the fact that the hand movements during 
writing could take any form or shape, a particular writer employs only 
a very limited set of pen strokes. The results of the clustering by var- 
ious methods, yields a limited set of only twelve to fourteen types of 
pen strokes that accounts for 90brain supposedly chunks information 
to minimize the required attentional resources. 
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keywords: handwriting, human motor control.chunking, automatic- 
ity, connectionism 

1 Humans motor behavior 

When we speak about "what the human brain tells the human hand" we 
speak about the kind of "motor control language*, that might exist between 
the brain" and the "hand". While this "brain-hand" communication can 
be approached from different points of view, we studv it from a behavioral 
perspective. That is. we investigate the evidence of chunks or what is referred 
to as motor programs", by analyzing the dynamic data collected during 
experiments in hand-writing recognition. Although all the results reported 
in this article consists only on the output of the handwriting process, we try 
to make the proposed model cognitive and biological plausible 

We'll start with the cognitive plausibility. There is a strong link between 
cognitive mechanisms and the human motor behavior. Handwriting is the 
way that humans express their thoughts through the use of a complex motor 
skill. Rosenbaum [12], presented handwriting as culmination of several in- 
ternal translation process. First, an abstract message or idea is constructed. 
Then, it is formulated into appropriate linguistic expression » and then trans- 
lated as a series of efferent commands. There is a basic similarity between 
speech and writing, so we can assume that both share the same underlying 
mechanism. The phonemes in speech, correspond to pen-strokes in writing 
and the morpheme in speech correspond to letters. The higher levels of ab- 
straction (i.e. words, syntax, lexicon, semantics, prosody and discourse) are 
probably the same. 

There is an empirical evidence, that the ability to sequence behavior 
whether in the linguistic domain or drawing domain, depends on a central' 
amodal mechanism [11]. If this is true, then motoric control should be consid- 
ered as obeying the same rules of the linguistic or other sequential cognitive 
mechanisms. On the other hand, some of the properties that we discover 
about the primitives of the motor control language, might be generalized to 
other cognitive activities. In the case of handwriting, the efferent commands 
are expressed as pen-strokes. It was found by Wright [17], that different pro- 
duction mechanism are probably controlled by the same high-level graphic 
representation. This view of hierarchical structuring, and a "virtual" repre- 
sentation of motor movement is supported by empirical evidence. Humans 
can write in a consistent style when they write in small letters in their note- 
books, or when writing much bigger characters on a blackboard. Moreover 
peop e can write with a consistent style (same pen-strokes), when using dif- 
ferent effectors like hand and foot. * 
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As in any behavioral research, resulting behavior is influenced both by 
the general properties of handwriting and by properties which are specific 
to an individual writer. This means that a considerable part of the variance 
can be attributed to individual differences. It has been noticed by many 
researchers that handwriting style is so distinctive, that writers can" be rec- 
ognized according to their hand writing. This is also a common knowledge, 
and therefore signatures are recognized as a unique identifier of a specific 
writer. Some theories even associate personality traits with hand-writing 
style. As we intend to show in this article, the primitive pattern of writing, 
are unique for individuals writers. 

As any other cognitive or motor activity, human motor control goes 
through a process of development that is equivalent to intellectual develop- 
ment. An interesting well known phenomena is that children's drawing (and 
after that writing), becomes more refined over the course of development. It 
has been suggested by many researchers, that early drawing behavior corre- 
lates with young children's cognitive abilities. Van sommers [15], suggested 
that drawing may be governed by high-level rules, similar to those governing 
language processing, and that the development in drawing may parallel the 
development of language. Goodnow and Levine [9j even suggested a: "Gram- 
mar for action: sequence and syntax of children's copying." They reported 
several rules for sequencing drawing strokes. Examples of such rules were:" 
Start at leftmost point", "Start at top", "Start with vertical strokes", "draw 
horizontal lines from left to right*, etc. The evolutionary rationale for such 
rules could be to simplify motor planning. 

The biological plausibility of an hand writing model, involves two parts: 
The plausibility of the assumed neurological control, and the biomechanical 
properties of the hand. The preservation of the writing style while using dif- 
ferent muscles and even organs, is one of the most intriguing questions. The 
automaticity of writing, suggests a chunking mechanism, but this chunking 
mechanism is probably not in the motoric system of the hand, but somewhere 
in the upper control levels of the brain. Therefore, whenever we refer to 
the "hand", we do it metaphorically. I.e. the "hand" represents the efferent 
mechanism that accomplishes the motoric control. Recently, Alexander et al. 
[3], raised the question whether the specific concept of a "motor program", is 
an appropriate foundation for the development of biological plausible models 
of how the brain controls movements. While our current knowledge about 
the cortical and basal ganglia motor areas is still far from allowing a specific 
model, it can suggest what models are more neurologically plausible than 
others. Fischbach [7] discusses the finding about "face cells" and "motor 
command cells" as an evidence for abstraction in the brain. In the monkey's 
visual system, "face cells" located in the inferior temporal sulcus, were sug- 
gested as* representing a high level of abstraction. These neurons respond to 
faces but not to other visual stimuli. Face cells have their counterparts on the 
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motor side. "Command" neurons have been identified in certain vertebrates 
that trigger fixed action patterns. Georgopolos [lj recorded electrical activ- 
ity of single neurons, and found command neurons in the monkevs motor 
cortex (precentral gyrus) that encode the direction of forelimb movement. 
The firing of these neurons was not associated with the contraction of a par- 
ticular muscle or with the force of the coordinate movement. Georgopoulos 
computed a vector by summing the firing frequencies of many neurons, and 
found that it is more correlated with the direction of movement than is the 
activity of any individual cell. The vector becomes evident several millisec- 
onds before the arm moves. He interpreted this result as evidence for motor 
neuron planing. Damasio and Damasio [4] discussed the linguistic behavior 
of patients with lesion in the left posterior temporal and inferior parietal cor- 
tex. It was found that such patients have problem in producing word forms 
from the available phonemes. Analyzing the accumulated empirical finding 
on language structures, gathered with assistance of imaging techniques like 
MRI (Magnetic Resonance Imaging) and PET (Positron Emmision Tomog- 
raphy), shows that linguistic activity like naming, involves the motor cortex 
activation together with anterior and posterior language centers in the left 
hemisphere. Writing is a language activity which involves a production cen- 
ter that forms words and activates the "command cells" in the motor cortex 
to produce pen-strokes sequences (letters) and written words. In the same 
way that speech is composed of a small set of phonemes, we argue that 
handwritten letters are composed of a small set of pen-strokes. 

In addition to the neurological plausibility, there are biomechanic con- 
straints on the "hand" part. Some general principles have been suggested 
as governing this control mechanism. For example. Flash and Hogan [8], 
proposed that humans tend to write in a way that minimizes jerk. That is,' 
the third time derivative of the position signal. A more recent study [6], 
suggested the snap, which is the fourth derivative of position, as the cost 
function that is minimized. As we will see, there are alternative hypotheses 
about the. type of constraints imposed on the biomechanics of handwriting. 
In spite of the fact that the principle that governs the handwriting might 
be universal, each writer has its own unique variation. The differences are 
more pronounced in the unwritten strokes (the pen movements that do not 
touch the writing surfaceO than in the written ones. The friction of the pen 
with the writing surface diminishes the characteristics of the hand control 
mechanism which are better revealed when the pen is up. 

The article starts with reviewing theories of "motor programs", and ar- 
guing against that tepm and what it implies. We'll propose an alternative 
connectionist model of primitive hand- writing patterns and argue that it is 
more biologically and cognitive plausible. Then, we describe the experiment, 
and the collection of the data. The fourth chapter will describe the analysis 
of the collected data, and the conclusions that were drawn from this analy- 
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sis. The last chapter will discuss the results, and compare our conclusions to 
alternative ones. We shall conclude the article by pointing out some future 
directions and implications of the suggested model. 

2 Attention, chunking and "motor programs" 

The concept of "working memory- is modeled after the "working memory" 
in a (von Neumann) computer, where the registers in the Central Processing 
Unit (CPU) have a similar function. This is also whv researchers in that field 
prefer to talk about "motor programs". "Motor programs" are supposed 
to save attentional resources. According to this approach, it is assumed 
that the brain controls movements like handwriting, by executing "motor- 
programs", much like software is used in a computer (e.g. [12J ). The "motor 
program" concept is attractive, as it reduces the complexity of the sequential, 
analytical approach by using pre-programmed sequences of a limited number 
of generic motor commands (or routines), to control a large repertoire of 
movements. Alexander et al. [3] points out difficulties with the neurological 
plausibility of "motor programs" that imply separation between "software" 
and "hardware". For example, what would constitute the software in such 
a model, and where it is stored when not executed, how are they assembled 
prior to their execution and how new programs are created. A major problem 
with the "motor program" approach is also the sequencing of performance: 
goal- directed movements are supposed to be translated into trajectories, 
then to joints kinematics. Muscle activation cannot be computed until the 
inverse dynamics is calculated and so on. Therefore, argue Alexander et al., 
signs of specialization for such transformations should have been found in 
the cortical and basal ganglia. Thusfar, neurobiologies! evidence seems to 
indicate lack of such specialization. 

It is assumed that the processing capacity is limited, and therefore sev- 
eral tasks that have to be carried out simultaneously compete on the same 
resources. The main "problem" of human-beings and other organism might 
be, that we lack a "parallel output channel". All the output channels, be it 
speech, handwriting or any other motor output, are all serial in nature. It 
might be that this serial output suggested a serial cognitive mechanism as 
well. It is the conjecture of the neural-nets literature, and of this article, that 
the underlying mechanism is parallel and distributed over millions of simple 
processing units (neurons). Therefore, the term "motor programs", that im- 
plies a serial symbolic process running in the "brain-computer" might be 
misleading. We prefer to speak about "motoric schemas", which are motoric 
patterns invoked by activation of an assembly of neurons. 

The connectionist view of schemas (Smolensky, 1986) is that stored knowledge- 
atoms are dynamically assembled at the time of inference, into context- 
sensitive schemata. Rumelhart and McClelland (1986) (14) proposed a tech- 
nique that suggests how an attentional selective mechanism might work. 
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They propose the use of a set of mapping units which produce "dynami- 
cally programmable connections" and achieve focusing on different features 
on different times. Smolensky (19S6) maintains that schemata are coherent 
assemblies of knowledge atoms, where coherence or consistency is formalized 
under the name of harmony. He proposes the harmony principle: the cogni- 
tive system is activating coherent assemblies of atoms, and draws inferences 
that are consistent with the knowledge represented by the activated atoms. 

In much the same way, we propose to speak about "motoric schemas". 
This is consistent with our conjecture that there is no essential difference 
between the so-called "cognitive* 1 and "motoric" brain. mechanism. The con- 
nectionist schema-model is also consistent with the neural evidence, that 
the specialization among different cortical motor areas are related to certain 
sequences of movements, and not to transformations as proposed by the "mo- 
tor program" literature. According to our conjecture, preparatory units and 
movement executing units will belong to the same schema. This is supported 
by the anatomical fact that the three motor areas (SMA - Supplementary 
Motor Area. PMC - Primary Motor Cortex and Putamen), has the same 
proportion of target dependent motor cells and limb dependent movement- 
related cells ([2] ). Another supporting evidence is that neuronal population 
that were supposed to represent different stages of computation (according 
to the "motor program" view), have been shown to be active simultaneously. 

3 The experiment 
3.1 Data collection 

Rumelhart [13] developed a system which learns to recognize cursive script as 
it is generated by a writer. This system learns from examples of cursive script 
produced by a number of writers and recorded. He collected approximately 
1000 words from each of 58 writers. The average length of a word is about 8 
characters, That sums up to nearly 500,000 examples of handwritten cursive 
characters. His results were encouraging and had been used in this research. 
While Rumelhart [13] was mainly interested in handwriting recognition, this 
article uses the same data to investigate the writing mechanism. 

The data were collected in the following manner. Each word in the corpus 
was recorded. It was then played to the writer who was instructed to write 
the word on a tablet digitizer. The resulting x coordinate, y coordinate and 
an indication of whether the pen was or was not on the paper were sampled 
each 10 milliseconds. The resolution ( more than 200 dpi) and the sampling 
rate (100 samples/sec) are those that are shown to be appropriate in the 
on-line hand-writing recognition literature ([16] ). The data was saved as 
files, and has been used for the analysis reported in this article. 
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In addition to the data from Rumelhart's experiment, several thousands 
pen strokes of Japanese handwriting were, collected. Most of the data has 
been collected from hand written Hiragana characters, but some data has 
been collected during writing Kanji (idiographic) Japanese characters. Hi- 
ragana characters has the curved shapes of english hand printed characters, 
but without the ligature of cursive handwriting. 

Preprocessing of the hand-writing raw data has been made, with the 
goal of extracting features that will be used to segment and characterize the 
"pen-strokes". A pen stroke was defined as a segments of the cursive writing 
signal, between two consecutive zero crossing of the vertical velocity of the 
pen movement. Each character was segmented to several segments or "pen- 
strokes". A typical writing rate in English is two letters per second. Writing 
Japanese characters (Hiragana), takes about the same time, and a typical 
Hiragana character can be written in 0.3 - 0.5 seconds. 

3.2 Segmentation and feature extraction 

The principle of segmentation and feature extraction is to segment the con- 
tinuous signals into discrete segments and to represent each segment by a 
feature vector in the feature space. 

The segmentation that produces "pen-strokes" out of the continuous sig- 
nals, depends on the different definitions of the term" pen-strokes". While 
most of the literature about on-line character recognition is using this term, 
there isn't an agreed upon definition of a "pen-stroke". For example, one 
often finds only the pen-state change as the only criteria. That is, defini- 
tion of a stroke as continuous pen-movement, between pen-down and pen-up 
consecutive states [16). 

Once a "pen-stroke" is defined, there are many ways to represent it in 
a feature space. The on-line character recognition research employs several 
orthogonal transformations such as a discrete Fourier transform of the curve 
segments corresponding to the pen-strokes. That is, a pen-stroke is repre- 
sented by its Fourier coefficients obtained from its x{t) and y(t) signals. Es- 
sentially, any orthogonal transformation (e.g. Walsh transform, Karhunen- 
Loeve) could do in approximating the pen-strokes curves. That is, Plane 
curves can be approximated by orthogonal functions (Sinusoidal, polynomial 
or even square waves). This description can be also easily converted to the 
frequency domain, as was done in several studies of hand-writing recognition 
(16). 

This mapping of the time domain to a parametric domain is advanta- 
geous when the characters can be represented by a small number of coeffi- 
cients. Therefore, periodical smooth curves lend themselves better to mod- 
eling by harmonic functions, as one needs less coefficients. On the other 
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hand, straight line strokes require high order harmonies as they include high 
frequency components. This is why sinusoidal approximation is useful for 
characters consisting of curved strokes, as found in English cursive script, 
more than for Japanese Kanji characters (that are made mainly of straight 
line segments). K-L expansion has been proved to be a successful algorithm 
in machine-printed Chinese character recognition. Another successful at- 
tempt was to use a modified Hough transform for recognition of Chinese 
hand- written characters. The Hough transform is a technique for line detec- 
tion and has been generalized to detect arbitrary shapes. Chinese characters 
are line-like, and therefor lend themselves naturally to a Hough transform 
representation. 

The segmentation and feature extraction methods depend of course, on 
the goal. If the goal is pattern recognition, then the segmentation and feature 
extraction are geared toward discrimination between the various patterns. In 
our case, we looked for a segmentation and features that are biological plau- 
sible. Consequently, we investigated only features that might be explained 
by the neurobiological control structures, like the direction of the strokes, 
their curvature etc. 



3.3 Hollerbach's model 

The segmentation and feature extraction mechanism employed was, to de- 
velop a model of the underlying handwriting process and to describe the data 
in terms of the parameters of the model. The model employed was derived 
from that of Hollerbach [10] and involved the assumption that the genera- 
tion process could be described as pair of coupled oscillators. The coupled 
harmonic oscillators is just one of the many models that exist. Actually, 
its basic assumption about the symmetric shape of the velocity profile (an 
half sinus shape), is probably an oversimplification. The literature about 
velocity profiles of pen-strokes usually assumes an asymetrical bell-shaped 
velocity profile. That is, a rapid-aimed movement described by a log-normal 
velocity profile is considered as the fundamental unit (stroke). More com- 
plex movements are described in terms of superimposed log-normal curves. 
The asymmetric nature of the velocity bell-shaped profile results from the 
global stochastic behavior of a large number of processes involved in velocity 
control. 

In spite of being an oversimplified and inaccurate model, it has a clear 
advantage that it is based on a control mechanism, and is neuorobiologically 
interpretable. This model assumed that: 

x = acos(u; r Z 4- <p) + c (1) 
y = bcas(u v t) (2) 
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In words, the idea is simply that writing involves two orthogonal pendular 
movements. If we speak about writing in a notebook (small size letters), we 
can think about the wrist horizontal movements (actually, it is more arc-like 
movements) and the fingers flexion andextension vertical movement. These 
two movements can be considered as independent. If the size of the letters 
is more than an intch, than the arm muscles are involved. 

According to this model, The y-axis consists of a series of up/down strokes 
whose velocity profile is assumed to be sinusoidal. The x-axis is also pendular 
with a constant velocity, c, to the right. Different characters are made by 
modulating the relative amplitudes, a and 6, the relative phase, phi. and the 
relative frequency w x and u y , in the x and y directions. It is, furthermore 
assumed that the parameters change only when the velocity in the y direction 
reaches zero (end of pen-stroke). Thus, we define a stroke as the motion 
between zero crossings in the y velocity - v y . In addition, segmentation 
occurs when the pen-state changes (from pen-down to pen-up or vice versa). 

It should be stressed that Hollerbach's model was designed for synthesiz- 
ing handwritten-like character, by a second order mechanical system. This 
model does not try to imitate the human motor control, or to be used for 
analysis of human handwriting. However, as it is a control system model, 
some of the parameters might be interpreted in terms of the human biome- 
chanical system. For example, the parameter 0, which designates the phase 
shift, can be interpreted as relating to the delay in the nervous-muscular 
control system. As such, it can have an important diagnostic value in motor 
diseases. 

When it was applied by Rumelhart to handwriting analysis, it suffered 
from some drawbacks. One of them is that the model is fitted not to the 
image, but to the velocity profile of the stroke. This simplifications tend 
to work well in most of the cases of English cursive hand-writing, because of 
the periodical nature of the v v velocity signal. 

As the Hollerbach model that we used, is based mainly on the velocity sig- 
nals, we will illustrate the transformation from the x - y domain of the hand- 





Figure 1: The handwritten letter d 
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Figure 2: The v z graph for the handwritten letter d 

written character, to the corresponding velocities. Examples of the handwrit- 
ten letter d, the corresponding velocity profiles and the reconstructed d are 
shown in Figures 1,2,3 and 4. 

As can be seen, the reconstruction isn't perfect, and the curvature of the 
first pen-stroke of the d is opposite to the original. This result illustrates the 
fact that the model tries to reconstruct the velocities and not the resulting 
pen strokes image. 6 

This does not exclude the fact that sinusoidal approximation worked for 
Rumelhart m recognition of cursive script. It turned out that in some cases 
(periodic signals during cursive handwriting in English) the model worked 
satisfactorily. 

The Kanji characters, on the other hand, have more short straight seg- 
ments, as can be seen in the following figures: 

The "mori" Kanji character in the picture, is segmented to 27 pen-strokes 
(the last two pen-down strokes in the third "tree" are missing). Sixteen out 
of the twenty seven, are strokes in which the pen touched the paper, and 11 
were just for moving the pen from one line to the other. Twelve sequences of 
pen-down" strokes, correspond to the visible line segments in the character 




Figure 3: The v y graph for the handwritten letter d 
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Figure 4: The reconstructed letter d 
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Figure 5: The separate strokes are more evident in Japanese Kanji characters. 
This is the Kanji character: "'mori", which means: forest 
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Figure 6: v v sipal for t he Kinji c haracter: "mori 




Figure 7: The reconstructed Kanji character: 



raon 



The reconstructed Kanji character is depicted in the figure. 

3.4 Recognizing pen-strokes sequences 

One of the key problems in recognizing cursive handwriting is the segmen- 
tation problem. Rumelhart (13) has devised a learning algorithm for cursive 
handwriting recognition which combines word recognition and letter recog- 
nition. The letter recognition is based on recognizing PMPs, and PMPs 
sequences make letters. This system involves simultaneously learning to rec- 
ognize and segment letters. 

Although Rumelhart 's experiment was done for hand-writing recognition, 
there are several things that can be learned from it, concerning the PMPs and 
their sequencing during handwriting. It was recognized in the early sixties 



SUBSTITUTE SHEET 



WO 94/09447 



PCT/US92/08703 



- 27 - 

([6]), that motor knowledge can be used in recognition of hand-writing. A 
system called Analysis by synthesis suggests that characters are recognized by 
their "motor programs". These "motor programs" are supposedly deduced 
by guessing an initial program, and iteratively updating it according to the 
difference between the synthesized and actual forms. The connection between 
reading and writing process have been corroborated by the co-occurrence of 
certain kinds of acquired dysgraphia and dyslexia ([5]). In contrast to ear- 
lier approaches, Edelman et al., ([6]), assumes that while readers use motor 
knowledge in reading, they do not seem to do so by mentally reproducing 
the process of writing. The connectionist model that we propose isn't both- 
ered, of course, by those distinctions between explicit simulation or implicit 
knowledge. This is another example of the misleading influence created by 
the "motor programs" metaphor. 

4 The results of clustering 
4.1 fixed radius clustering 

The basic units of clustering were the pen-strokes, each of which was rep- 
resented as a point in an n dimensional space. Out of the six features that 
we extracted for each stroke only three have been used. First, we used only 
one frequency for the modeling, so the rare strokes that involved higher har- 
monies were removed. Second, we did not differentiated between Up-strokes 
and Down-strokes. Up strokes contain more high order harmonies, but we 
limited our analysis to the basic movements, and tried to ignore the fluctu- 
ation induced by the bio-mechanical control mechanism. The third feature 
that wasn't used was the mid-point. For the reconstruction of the pen-strokes 
in the spatial domain, the r-coordinate of the midpoint in each stroke was 
computed. However, our preliminary analysis showed that this variable was 
very highly correlated with the x variable. This preliminary analysis, yielded 
three variables that were almost uncorrected: and velocity. The 

dimension of the space were: 

1. A v - The relative displacement on the vertical direction. 

2. A r - The relative displacement on the horizontal direction. 
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3. v - v The t; x velocity at the end of the stroke is calculated according to 
equation below. 

For a pen-stroke between a and 6, which is approximated by a certain 
oscillation frequency, we calculate: 



It is calculated in a different way for different u?t and this is an example 
of such a calculation. 

The clustering of data from many writers, didn't yield satisfactorily clus- 
tering, but the clustering of individual writers did. E.g. the clustering for a 
particular writer, revealed 13 compact clusters that contained 90to 14, were 
consistent to all the writers we analyzed. This is a corroboration to our con- 
jecture that hand writing is made out of a small number of PMPs, which are 
unique to an individual writer. 

The centroids of the clusters, were reconstructed from the feature space, 
and are displayed on a 2-D spatial domain. As can be seen clearly from the 
results, different writers have different stroke types: 

As each writer has about 25,000 pen-strokes that we wanted to cluster, 
we started with a fast clustering algorithm, similar to the k- means algorithm. 
The main requirement of the clustering algorithm were that it will be able 
to deal with very large data sets and find satisfactory clusters in few (2-3) 
iterations. The other requirement, which was even more important* was that 
the centroids will be good representations of the observations within each 
cluster. This requirement lead to seeking compact, hyperspherical clusters, 
thai do not exceed a predefined radius. Elongate clusters are therefore repre- 
sented by several adjacent clusters. Those clusters will be merged in a latter 
stage by an hierarchical clustering algorithm. 

The clustering employed a two phase strategy. First, a fast "nearest 
centroid sorting" algorithm was employed to reveal the clusters in the large 
data set. Then, the resulting centroids of the clusters have been submitted 
to different hierarchical clustering methods. The fir* phase algorithm wa» 
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Figure 8: Clustering of 25,000 strokes of the same writer. Gray clusters 
represent down strokes. 



—J-.,,. 

in - 








24 






5 


* 


7 




^ 15% 












i — * 

Dmmm/ 

" ( 


• 























/J 



7* 

MB 



Figure 9: Thirteen centroid pen-strokes of an individual writer, including 
their relative frequencies. 
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sensitive to outlier strokes, that formed separate clusters. This was the reason 
why we got many very small clusters. These clusters accounted for le^han" 
lOof the observations They were considered to be noise, or very ex'tiond 
pen strokes, and have been removed so not to influence the representativeness 

of the centroids of the large clusters. 

diff^V eC0 ^ P haS " inC ! uded Cl " sterin « of th « suiting centroids using ten 
d.fferent methods. We dist.ng UI shed between methods that yield compact 
hypersphencal clusters, and those that can detect elongate clusters We 
start with the first group of eight clustering methods: 

1. Average Linkage cluster analysis 

2. Centroid hierarchical cluster analysis 

3. complete linkage cluster analysis 

4. Equal variance maximum likelihood method 

5. Flexible data cluster analysis 

6. McQuitty's similarity analysis 

7. Medi an Hierarchical cluster analysis 

S. Ward's minimum variance cluster analysis 

The different methods tend to favor different characteristics such as size 
shape or dispersion. For example, methods based on the least-squares cri- 
terion such as k-means or Ward's minimum variance method, tend to find 
clusters with roughly the same number of observations in each cluster Aver- 
age linkage is biased toward finding clusters of equal variance. Most cluster- 
ing algorithms, except for single-linkage and density-linkage, tend to produce 
compact, roughly hypersphencal clusters. The clustering methods which are 
based on nonpaxametric density estimation, like the single linkage, will be 
discussed later in this chapter. 

All the above clustering methods yielded very similar results, and the 
tree-based partition was essentially the same. The use of many different 
algorithms has been employed to investigate the robustness of the clustering 
structure under different hierarchical clustering methods. The result of all 
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Figure 10: Hierarchical (compact) clustering of the 12 pen-strokes centroids 
of a particular writer 

the above method revealed the following tree-based partition of the set of 
the basic twelve pen-strokes (of a particular writer). 

From looking at the results of the hierarchical clustering, there is an ob- 
vious super-clusters that emerge. The horizontal-left strokes are one such 
a group, long down strokes are another group. In general we see a distinc- 
tion between horizontal strokes and vertical strokes. The horizontal strokes 
themselves are subdivided to horizontal-left directed strokes, and horizontal 
right and up directed strokes. The high velocity C shaped strokes are part 
of circles or ovals. It should be noticed that for a specific writer, a certain 
stroke is always accomplished in the same way. For example, an horizontal 
short stroke, like crossing a t, will be done always as left directed strokes. 
Someone else could use only horizontal right directed strokes for that pur- 
pose. However, it is very unlikely that the same writer will use both an 
horizontal-left and horizontal-right strokes. The same is true with long ver- 
tical strokes. Once the writer is using a long vertical down-stroke, he will 
produce vertical lines always as down strokes of the same type and velocity 
profile. This organization of pen strokes was consistent in all the hierarchical 
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Figure 11: Hierarchical (Density linkage) clustering of the 12 pen-strokes of 
the same writer 

clustering algorithms that we mentioned above. 

The clustering methods that employ nonparametric density estimation, 
like the "Density linkage cluster analysis", can detect also elongated cluster 
shapes. These clustering techniques yielded two distinct super clusters: the 
"down and long pen-strokes" , and the "up and right strokes". The down 
strokes are those that form the "back-bone" of the English characters, while 
the up-right strokes are typically those that are used as ligature. 

4.1.1 The "characteristic" shape of pen-strokes 

Aa was argued above, any writer has a specific set of pen strokes that char- 
acterize the writer. While the same writer will have similar pen-strokes, in 
writing different languages, the frequency of appearance of a specific pen 
strokes depends, of course, on the language. In order to characterized a spe- 
cific writer, in respect to her/his pen strokes, we suggest the "Pen-strokes 
Ordering Diagram" (POD). Such PODs are displayed in the following figures. 

In spite of their strange looking, those diagrams are quite valuable,, and 
convey important information about the handwriting of the analyzed writer. 
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Figure 12: The centroids of the pen strokes of a writer, for English cursive 
writing. The pen-strokes are ordered according to their v y values, from up- 
strokes to down strokes 




Figure 13: The centroids of the pen strokes of a Japanese writer, for Japanese 
Hiragana characters. The pen-strokes are ordered according to their v y val- 
ues, from up-strokes to down strokes 
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Figure 14: The centroids of the pen strokes of a Japanese writer, for english 
characters. The pen-strokes are ordered according to their v y values, from 
up-strokes to down strokes 

There is a very clear distinction between the key strokes that these two 
writers are using. This is true to other writers as well. Each writer uses 
a unique set of pen-strokes: " different slopes, different curvetures, different 
velocity profiles and accelerations. 

5 Discussion and future research 

We will start our discussion with comparing the conclusions of Rumelhart's 
handwriting recognition experiment, and the conclusions of this study. In 
Rumelhart's handwriting recognition experiments, both writer dependent 
and writer independent recognizers have been trained. Two networks have 
been trained to recognize the writing of individual writers and one network 
has been trained on four different writers as a 71 writer independent" recog- 
nizer. On the writer dependent networks Rumelhart found that, for a vo- 
cabulary of 1000 words, on words never seen during training that 99top Ave, 
approximately 90On the writer independent data the results are somewhat 
worse. That is, about 70 

According to the results in this study, we have a basis to doubt this 
conclusion. The inter-writer variability is too big, and more writers will not 
lead necessarily to better results. 

Another finding of Rumelhart was that writers can be trained easily to 
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produce recognizable hand writing. He developed an "online" system in 
which the network recognizes (and can be trained) as the writer writes on 
the digitizer. With a little care on the part of the writer it is not difficult to 
achieve a score of better than 90correctly classified on the writer independent 
system. (It is aiso possible to write so that the recognizer does much more 
poorly than that.) Careful experiments on a person's ability to adjust to 
the recognizer have not been carried out. By limiting the vocabulary to 
one hundred words or less, it seems to be possible to obtain near perfect 
performance. (It will, of course, depend on the confusability of the words.) 

The main conclusion was. that it would be useful to embed the recognizer 
in a network of networks each trained on a subset of the writers - perhaps one 
for printers, one for pure cursive writers etc. This line of thought led to the 
current study, reported in this article. That is, that it may be useful to study 
the individual differences among the writers. The idea of studying individual 
differences, as a mean towards better handwriting recognition, turned out to 
start a new line of research - the study of writer's unique pen-strokes, which 
is related to the topic of automaticity in brain - hand communication. 

This study started from that point. The main question that we posed 
was if individual writers have distinct sets of pen-strokes, which are con- 
sistent and well defined. The reanalysis of the data from this perspective 
encourage to believe that this is the case. Human writers have 12-14 distinct 
pen-strokes, which are characteristic for a certain writer. These pen-strokes 
are the primitive "'motoric patterns", of which handwriting is composed. We 
showed also that the primitive pen-strokes cluster to super-clusters, thus re- 
vealing the hierarchical nature of the control mechamnism. These findings 
are consistent with the neurological literature, that we cited in the introduc- 
tion. That is, there might be "command cells", that get the activation for 
certain words (letter combinations) from another center in the brain and acti- 
vate pen-strokes mechanism. The pen-stroke is controlled by a direction and 
amplitude cells, that activate the corresponding primitive motoric patterns 
(PMPs). The next stage will be to locate the cell regions that are responsi- 
ble for this activation in the motor areas of the human brain. This is under 
research now with the help of Magnetic Resonance Imaging (MRI) method, 
when the MRI is tuned to detect cerebral blood flow. We would expect that 
the learning to write, should show itself as forming of such motoric activation 
centers, corresponding to what we have found in this study. 

Those findings have implications to the study of automaticity and chunk- 
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ing. One question to be investigated is if the motor control mechanism is 
central and a modal, as suggested by previous researchers. This can be in- 
vestigated by studying the patterns of interference between modalities. For 
example, an experiment in which the subject is instructed to pronounce one 
character, and write another character at the same time. In addition to pre- 
dicting longer Reaction Time, we can now predict interference between the 
pen stroke patterns and sequences. Another interesting question is how are 
the motoric patterns stored and how are they retrieved when needed. Our 
conjecture, which is consistent with the neural net model, is that the retrieval 
time will be independent of the number of patterns sequences. Some sup- 
port for this conjecture is that it takes the same time to write a character 
in a large character set (kanji) or small character set language (Hiragana, 
English). 

Future research that will combine behavioral analysis with neurobiolog- 
ical research, might answer many of the questions that we raised in the 
introduction. 
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APPENDIX 8 



feat[0] 
feat[l] 
feat[2] 

feat[3] 
feat[4] 

feat[5] 

feat[6] 
feat[7] 
feat[8] 

faat[9] 

feat[10] 

feat[ll] 

feat[12] 
feat[13] 
feat[l4] 

feat[15] 
feat[l6] 
f««t(17] 

feat[l8] 
feat[19] 
f«at[20] 

feat[21] 
feat[22] 
feat[23] 

feat[24] 
faat[25] 
reat[26] 
feat[27] 

feat[28] 
f«at[29] 
faat[3e] 

reat[31] 
faat[32] 
faat[331 
faat[3«l] 

faat[35] 
faat[36] 
feat[37] 
faat[38] 

faat[39] 
feat[40] 
reat[4l] 
feat[42j 



relative sire of ayabol 32*div_round { Xwidth . ywid th ) 
nuober of points 
number of strokes 
number of spaces 
nuober of different levels in X 
number of different levels in Y 



for end of space 
for end of space 



number of Ext X in neg.rot 
different levels in X for minX 
different levels in Y for oinX 

number of Ext in X pos.rot 
different levels in X for maxX 
different levels in Y for aaxX 

number of Ext in Y neg.rot 
different levels in X for oinY 
different levels in Y for ainY 

number of Ext in Y pos.rot 
different levels in X for maxY 
different levels in Y for aaxY 



number of ExtXY 
different levels 
different levels 



for neg. rot 

in X for feat 41 

In Y for feat 41 



number of ExtXY for pos. rot 
different levels In X for feat 44 
different levels in Y for feat 44 

number of arc parts 
number of circle parts 
number of X-levels in symbol 
number of Y-levels in symbol 

number of linear strokes (in_rot"»0) 
number of pos. rot. strokes (in_rot«»l) 
number of neg. rot. strokes (in_rot«7) 

number of linear strokes where dir-0,1 

number of linear strokes where dir«2,3 

number of linear strokes where dir-4,5 

number of linear strokes where dir-6,7 

number of strokes where out_rot-0.1 

number of strokes where ou t_rot«2 , 3 

number of strokes where out_rot-4 f 5 

number of strokes where out_rot-6,7 

number of spaces where q-0.1 

number of spaces where q a 2,3 

number of spaces where q*4,5 

number of spaces where q s 6.7 



SUBSTITUTE SHEET 



WO 94/09447 



PCT/US92/08703 



- 40 - 



feat[43] ■ nuiber of spaces where out_rot»0.1 

feet[44] - nuiber of spaces where out~rot-2.3 

feat[45] ■ nuaber of spaces where out~rot-4.5 

feae[46] - nuaber of spaces where out~rot»6.7 

feat[**7] ■ number of oin X. 
feat[48] - nuaber of nax X. 
feat[*»9] • nuaber of Bin Y. 
feat[50] • nuaber of a ax Y. 

feat[51] • sua length of spaces. 
foat[52] - relative position of spaces. 
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APPEND.IX C 



# include <s td±o . h> 

^include <stdllb.h> 

^include <math.h> 

# include <conio.h> 

^include <values .h> 

^include <mem.h> 

# include < string, h> 

# include < process • h> 



^define GRID 15 

#define MAX NUM OF_P0INTS 1000 
#def±ne MAX~NUM~0F STROKES 64 
#define MAX~NUM_0F~EXTREM0MS 32 
#define NUM~FEAT 53 
fdefine NUM_SYMB0LS 72 
#define DIVISER 6 
#define TRUE 1 
#define FALSE 0 



typedef int boolean; 

struct TABLE_STROKES_NEW { 

unsigned strk_ num ; 

int delta_x ; 

int delta_y ; 

unsigned lenght ; 

unsigned pen_status ; 

int rotation ; 

}; 



struct POINT { 

unsigned x_cor : 10; 

unsigned y_cor : 10; 

unsigned pen status : 4; 

}; 



struct TAPLE_EXTREM0MS { 

unsigned p_ndx : 10; 

unsigned x^cor : 10; 

unsigned y_cror : 10; 

unsigned pen^sts : 1; 

unsigned dlr : 4; 

unsigned in_rot : 4; 

unsigned out_rot : 4; 

unsigned susp : 1; 

unsigned reserve : 4; 
}: 



struct FEATURES { 

char IDfeat[llj; / # Id feature for naie */ 
unsigned int feat[NUN FEAT]; 

} ; 
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feat[6] 
feat[l] 
feat[2] 
feat[3] 
feat[4] 
feat[5] 

feat[6] 
feat[7] 
feat[8] 

feat[9] 

feat[10] 

feat[ll] 

feat[12] 

f«t[13] 
feat[l4] 

faat[15] 
feat[l6] 
feat[17] 

feat[l8] 
feat[19] 
feat[29] 

feat [21] 
feat[22] 
feat[23] 

feat [24] 
feat[25] 
feat[26] 
faat[27] 

feat[28] 
feat[29] 
faat[38] 

f«at[31] 
feat[32] 
fe*t[33] 
faat[3*] 

feat[35] 
feat[36] 

featE37] 
f"t£38] 

feat[39] 
feat[46] 
feat[4l] 
feat[*2] 



relative aire of ayabol 32 # div_round(Xwidth . Ywidth) 
nuaber of points 
nuaber of atrokea 
nuaber of spaces 

nuaber of different levels in X for end of space 
nuaber of different levels in Y for end of apace 

nuaber of Ext X in neg.rot 
different levels in X for ainX 
different levels in Y for ainX 

nuaber of Ext in X poe.rot 
different levela in X for aaxX 
different levela in Y for aaxX 

nuaber of Ext in Y ner.rot 
different levela in X for alnY 
different levela In Y for alnY 

nuaber of Bxt in Y poe.rot 
different levela in X for aaxY 
different levela in Y for aaxY 

nuaber of BxtXY for oef. rot 
different levela In X for feat 4l 
different levela in Y for feat 41 

nuaber of ExtXY for poa . rot 
different levels in X for feat 44 
different levela In Y for feat 44 

nuaber of arc parte 

nuaber of circle parte 

nuaber of X-levele in ayabol 

nuaber of Y-levela in ayabol 

nuaber of linear atrokea (ln_rot»-9) 
nuaber of poa. rot. atrokea (in_rot«l) 
nuaber of neg. rot. atrokea (in~rot»«7) 

nuaber of linear atrokea where dlr-0,1 

nuaber of linear atrokea where dlr«2.3 

nuaber of linear atrokea where dlr-4,5 

nuaber of linear atrokea where dir-6,7 

nuaber of atrokea where out_rot«8»l 

nuaber of atrokea where out~rot«2,3 

nuaber of atrokea where out_rot«4,5 

nuaber of atrokea where out^rot-6,7 

nuaber of apacea where q«6»l 

nuaber of apaees where q«2.3 

nuaber of epacea where q*4,5 

nuaber of apacea where q a 6,7 
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feat[43] ■ nuiber of spaces where out_rot-G,l 

feat[44] - number of spaces where out~rot-2,3 

feat[^5] " number of spaces where out - rot-'* i 5 

feat[46] - number of spaces where out~rot«6,7 

feat[47] * number of min X. 

feat[48] - number of max X. 

feat[49] - number of Bin Y • 

feat[56] - number of a ax Y. 

feat[51] • sua length of spaces. 

feat[52] • relative position of spaces. 
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/# MAIN FOR TEACHING 

^include "main .h w 
^include "stdio.h" 
void oain( ) 
{ 

FILE *f_point ; 

struct FEATURES feat; 
struct FEATURES Bin feat; 
struct FEATURES aax~feat; 

int featO; 

int first_feat-l; 

int file_ndxl-2,file_ndx2«0; 

char Ct«Bp[10]; 

' # Sri:i%^: 1 u:c^nr cc,a flles whlch hold the i - f «»"« 
( 

FILE *PF: 

^ PF-fopen (-space". V) ;fclose (PF) ; 

system ("del space*. *"); 
/•systen ("del extra. out"); 
system ("del feat. out") ; •/ 

♦•25S2.5iS*riiS#.52S"i2iSf # 5!lS # 5i Y,Pen of the «y»boi-s examples 

••••••• • • / 

strcpy Unfile. *\\vork\\syB\\sya 1 ') ; 
strcpy (Symld, "sya") ; 

for (file_ndxl-0;file_ndxl<NUM_SYMBOLS;file_ndxl**) 

itoa (file_ndxl.Cteap.lG) • 
street (infila.Cteap) ; 
strcat (Syald.Cteap) ; 
street Unfile." .") ; 
strcat (Syald,*.") ; 

strcpy (Binf ile.infile) : 
strcpy ( BSyald, Syeld) ; 

file_ndx2-0; 

itoa~( file_ndx2.Cteap, 10) ; 
strcat (infila.Cteap); 
strcat (Syald, Cteap) ; 
first feat- 1; 
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while ( transfora(infile,4feat) I •©) 

strcpy ( feat. IDf sat, Syald) ; 

/♦print_f eatures { 4f eat , "feat .out "); •/ 

if ( f irgt_feat«l) { 

nin_feat"feat ; 

nax^f eat«feat ; 

first feat-0; 

} elae 7* update alniaui and aaxiaua feature according to feature 
of current symbol */ 

cale_liaita (Main.feat) . t(aax_feat) , feat) ; 

strcpy {infile.Binf lie) ; 
strcpy (Syald.BSyald) : 
file ndx2**; 

ltoa ( file_ndx2 t Cteap t 10) s 

street (infile.Cteap) ; 

street (Syald.Cteap) ; 
} /• of while •/ 
strcpy (»in_feat.IDfeat.BSyaId) ; 
strcpy (aax~feat.IDfeat t BSyaId) i 

if (firat featr-1) 
/• saves the «in feature and max feature of the syabol to disk •/ 
aave_ain_aax (ain_f eat ,aax_f eat) ; 

strcpy (inflle."\Work\\aya\\»y«") ; 
strcpy <SyaId t "sya") ; 
} /• of for V 

exit (9); 
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finclude "lain.h" 



/•This procedure is to read the points of the symbol froe a Tile and 

fill it in the array of coordinates : arr cor. 
V ~ 
int read_points (struct POINT arr_cor[ ] , char 'filename) 

FILE # fpointer; 
unsigned int x.y.p; 

unsigned int prev_x , prev_y , prev_pen ; 
unsigned int i-0,in»0; 

fpointer-f open ( f ilenane . " r*" ) ; 

prev_x»0; 
prev_y-0; 
prev_ pen-0; 

while ( {fscanf (fpointer, m %& 2d %d" , &x , £y , 4p ) >0) LL (p«-0)): 
while (fscanf (fpointer, -Xd %6 %d~ . tx.ty .&p) > Q) 

if (in/OIVISER*OIVISER in) { 
in**; 

arr^cor[ i] • x_cor*x ; 
arr_cor[i] . y_cor-y ; 
arr_cor[i] ,pen_s tatus-p ; 

if T ( (aba(prev_x-x)*abs(prev_y-y) )>3) || (prev penl-p)) { 

prev_x»x ; 
prev_y-y ; 
prev pen«p; 

) 

} 

else in**; 

) 

arr_cor[i] . x_cor«arr_cor[ i-1 ] .x_cor; 
arr_cor[i] . y_cor«arr_cor[ i-1 ] . y_cor; 
arr~cor[i] . pen_s tatus«0 ; ~ 



f close ( fpointer) ; 
return ( i ) ; 

> 
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/♦This aodule Includes general purpose procedures which ere • 

(1) def_quart : a funtion that recleves two nuabers , and returns 
the quarter of these two nuabers in the range of 0-7 

(2) div_round : a function to calculate the round ouiber of the 
division of two integer nuabers fte 

V 

finclude "aain.h" 

/ 

A funtion that recieves two nuabers f and returna the quarter of 
^^theae two nuabers in the range of 0-7. 

int def_quart (x.y) 
int x; 
int y; 
< 

if ((x>0 ) (y-e)) return (0); 
if (<x>0 ) kk (y>8) ) return <i)t 
if ((x«0) 14 <y>0) ) return (2); 
if ((x<0 ) kk (y>9) ) return (3) i . 
if ((x<0 ) u (y—ej) return (4); 
if ((x<0 ) kk (y<0) ) return (5); 
if ((x-«0) kk (y<G) ) return (6) i 
if ((x>G ) kk (y<0) ) return (7); 
return (15); 

) 

/ • 

A function to returna the round number of the division of two 
integer nuabers. 

int div_round (int a. int b) 
int i-9; 

int teapl,teap2; 

teapl*a; 
teap2-b; 
••abs(a); 

if (b--6) return (MAXIHT) ; 
while(a>b) 

{ 

if (b>0) a-«b; 
else a*-b; 

} 

if {(a*a)>b) 

if (((teapOO) kk (teap2>e)) || ((teaplO) 14 (teap2<9))) 

return (i); 
elae return (-i); 
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flnelude "aaln.h" 

/ 

calcualtes the space features of a syabol , (called froa 
calc_f eatures ) . 

######¥ # * ### * * / 

void calc space feat (struct TABLE EXTREHOMS extr[],lnt extras 

struct FEATURES *feat) 

{ 

int 1-0; 

boolean arr_x_levels[ 16 ] ; 
boolean arr_y_levels(i6] ; 
unsigned int sua*0; 

for (i»e;i<-15;i**) { arr_x_levele [ i ] -FALSE; 
arr y levels[l]«FALSE; 

> 

for (l>6;l<extras ;!*♦) 
{ 

if (extr[i].pen sts-»0) 

{ 

(•feat) .feat[51]-(*feat) .feat[51]* 
( ext r [ 1 ♦ 1 ] . p_ndx-ex tr[ 1 ] . p_ndx ) ; 
aua*-extr[i]7p ndx; ~ 
((•feat) .feat[3]**>; 

arr_x_levels[extr[l*l] »x_eor ]-TRUE; 
arr~y~levela[extr[i*l J -y~cor]«TRUB; 
switch (oxtr[i^l] .dir) {" 

case 0 : (* f eat ) . f eat[39 ; break; 

case 1 : (* feat ) . f eat[ 39]«^ ; break; 

case 2 : (* Teat ) . f eet[4e] ; break; 

caae 3 : (*feat) ;feat[40>* ; break; 

case 4 : (*feat) . feet[4l]** ; break; 

case 5 * ( # feat ) . f eat[4l ]♦♦ : break; 

case 6 : ( # feat) .feat[42]**; break; 

case 7 : (*feat) ♦feat[42]*+; break} 

default: break; 

} 

) 

(•feat) .feat[52]-div_round(8 # eua. (*feat) .feat[l]); 

for (i-9;i<«15!i**) { 

if (arr x le*ele[ i]-«TRUE) ( ( < # f eat ) . f eat[%] ) ♦♦) ; 
if (arr~y~levele[i]«TRUE> ( ( (*f eat) . feat[5] ) I 
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calcualtes the rotation features or a syabol . (called froa 
calc features ) . 



void calc rot (struct TABLE EXTREHOMS extr[].int extras, 
struct FEATURES # feat) 

{ 

Int 1; 

for (i«l;i<-extras;i** ) { 
switch (extr[i].ln_rot) { 
case 0 : { 

( ( # feat) .feat[28])+*; 
switch (extr[l].dir) { 



case 0 
case 1 
case 2 
case 3 
case k 
case 5 
case 6 
case 7 
default 



) 



(Teat) .feat[31]** 
(•feat) .feat[31]** 
(•feat) .feat[32]** 
(•feat) .feat[32]**; 
(•feat) .feat[33]**: 
(•feat) .feat[33]**i 
(•feat) .feat[3*»]**! 
(•feat) .feat[3*]**i 
break; 



case 1 : 
case 7 : 
default: break 



((•feat).feat[29]) 
( ( # feat) . feat[30]): 



break; 
break ; 
break ; 
break; 
break ; 
break ; 
break ; 
break; 



•*; break; 
break; 



} 

if ( (extr[i-l].peo_sta*extr[i] . pen_s ta ) *-2) 
switch (extr[l].out.rot) { 



case 0 
case 1 
case 2 
case 
case 
case 5 
case 6 
case 7 
default 



3 
4 



(•feat) . feat[35]** 
(•feat*.featC35]*» 
(•feat) . feat[36]** 
(•feat) .feat[36]** 
(•feat) .feat[37>* 
(•feat) .feat[37]** 
(•feat) .feat[33]*» 
(•feat) .feat[3d]** 
break; 



break ; 
break ; 
break ; 
break ; 
break ; 
break ; 
break ; 
break ; 



if "( (extr£i-l].pen_ets*extr[i].pen_sts)-»l) 

switch <extr[i].out.rot) 

{ case 0 : ( # reat) . f eat[43] : 

ease 1 : ( # feat) . feat[43] ; 

case z : (•feat) .feet[44]**; 

ease 3 : (*feat) . feat[44] : 

case 4 : ( # feat) . feet[45]** s 
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case 5 : ( * f e» t ) . f ea t[ *5 ] ♦ ♦ ; 
case 6 : ( * f est ) . f eat[ 46] ♦ ♦ ; 
case 7 : ( *feat ) . f eat[46]** ; 



' calcualtea the extreaua type features of a symbol , 
(called froa cale_f eatures ) . 

void calc ext types (struct TABLE EXTREMOMS extr[],int extras. 

struct FEATURES *feat) 



{ 



int i-0; 

boolean arr_x_levels[ 16] ; 
boolean arr3y_l« v «l»C » 

for (i-e;K-15;l**) { 
arr_x_levels[l]-FALSE; 
arr_y_levels[i] -FALSE; 

> 

for (i-l;l<extraf;i**) 

if |((extr[i].dir— 3)W((sxtr[i*l]-dir— 1) || (extr[i*t ] .dir«2)) > 

((extr[i].dir«7)*fc((«tr[i*l].dir--5) II (extr[i*l ] .dir--6) ) ) ) 

{ if ( (extr[i-l].pen_sts»extr[i].pen.ats)«2) 
(•feat) .feat[6]**; 

} 

• ••••• • / 

for (i-0;i<-15;i**> ( 
arr_x_levela[i]-FALSE: 
arr y levels[i]-FALSB; 

} 



for (i-1 ;i<extrsm:i*») 



U*tr[i]"ir--5)«((«tr[i*l].dir--7) II (extr[fl ] .dir»6» ) ) 
((Mtr[i].dlr--3)*fc((«*«[t*l].dir.-l) II (•xtr[i*l] .dir--2) ) ) 

(extp[i].dir--5) " <««er[l*l].dlr.-in || 
((•xtr[l].dlr--3) C4 (•xtr[fl].d±r..7)>> 

1 if ((•xtp[t-l].P««»_»«*««Ci].P«"»_«")"-2) 

1 arr x leyel«[extr[i] .x.eot] - TRUE: 
«rr~y~l«v«l«[«tr[i].jr_cor] - TRUB; 

> 

) 
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for (i-9ii<-15ii**) { 

if (arr x levela[i ]--TRUE) ( { ( • f eit ) . f eat[7 ] ) ♦ ♦ ) ; 
^ if <arr_y_levalati]"TRUB) ( ( ( • f eat ) . f •«t[8] ) ♦ ♦ ) • 

for (i-0;i<-15:i**) { 1 
«rr_x_lovela [ i] "FALSE i 
err y level* [ i] -FALSE ; 

} 

for { i" 1 ; Kextns ; i ♦ ♦ ) 

if jj(extr[i].dir«l)44<(extr[i*l].dir.-3) || <extr[i*l] .dir«2) ) ) 

<<extr[i].dir— 5)44( ( extr[i*l ] .dir--6) | | (Mtr[^l] .dlr--7) ) ) ) 



{ 



if ( (extr[i-l].pen_eta*«xtr[i] ,pen_sta) *-2) 

<Cf«at).featt9]**): 
arr_x_levale[axtr[i] .x.cor] ■ TRUE; 
arr_y_levels[extr[i] .y~cor] • TRUE; 
> " 



for (i"6ji<-15;i**) { 
arr x levela[ i ] "FALSE ; 
•rOOevale[i]-FALSB: 

) 

for (i"l: i<extra§;i**) 

If (((•xtr[ij.dir«7>44<{extr[i<>l].dir«5> II (axtr[i*l] .dir—6) ) ) 

extr[i] .dir-- 1)44< < extr[i*l ] .dir--3 ) | | <axtr[i*l] .dlr»2) ) ) 

(extr[l].dlr«*l) 44 (extr(i*l].dir--5) ) || 
( (extr[i].dir— 7) 44 (extr[l*l].dlr-«3) ) ) 



} 



if ( (extr[i-l] .pea ate*excr[i] .pen •ta)-«2) 

( 

arr_x_levela[extr[i] .x.cor] • TRUE; 
arr~y~levele[extr[i] .y cor] ■ TRUE; 

> 



for (i-e.;i<-i5:i**) { 

if (arr_x_levela[i]--TRUE) ( ( ( # f eat ) . f eat[ 10] ) ♦ ♦ ) ; 
If (arr y level»[i ] --TRUE) ( ( (*f eat) . feat[ll ] ) ; 

} 

/ # # 
for (i-e;i<-15;i**) { 
arr x levels [ i]-KALSB ; 
*rr>~levele[i]"FALSB; 

} 
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for (i-1 ;Kextrii ; !♦♦) 

if ( { (extr[i].dir--5)tt{ (extr[i*l].dir--3) 



{ 



( (extr[l].dlr>«l)&&( (extr[i*l ].dir--7) 

if { (extr[i-l] .pen_sta*extr[i] .pen »ta)--2) 
(•feat) .feat[I2]**; 



I (•xtr[i*lJ.dir-«4))) 
(extr[i*l].dir«G)) )) 



for <i-e;i<-15:i*+) { 
arr_x_levela[i]-FALSE; 
arr y levels[ i] •FALSE; 

} • 

for (i-i ;i<extraa;i+*) 

if ( | (extr[i].dir«7Ui({«xtr[i*l].dir«l) 

extrCi].dir«5)14({extrCi*l].dir«3J [ 

(extr[±],dir«-5) 4t (extr[i*l ] .dir--l) ) | 
<<extr[i].dir--7) 41 (extr[i*l ] .dir«-3)) ) 

if ( <extr[i-i] .pen_eta*extr[i] ,pen_ata)«2) 



(extr[i*l].dir— 9)) ) 
(extr[i*l].dir— 4))) 



} 



arr_x_level«[extr[i ] .x_corJ ■ TRUE; 
arr_y~lavela[extr[i] .y%or] - TRUE; 



for (i-0;i<-15;i**) { 

if <arr_x_levela[i]~TRUE) ( ( (V eat) . feat[13] )♦♦) ; 
if <arr_y_levela[i]~TRUB> ( ( {•'f eat) . f eat[l4] ) ♦♦) ; 



for <i-9;i<-15:i**) { 
arr x levela[ i]-FALSB ; 
ar r.yllevela [ i ] -FALSE ; 

) 

for ( i-1 iKextrn ji** ) 

if | j (extr[i] .dir--3UM (extr[i*l] .dir« 5) 



) 



( (•xtr[i].dir--7U4( (•xtr[fl].dir--l) 

if ( (extr[i-l] .pen ata*extr[i] . pea ata)-«2) 
(•featX-faat[15l**: 



(extr[l*l].dlr«-4))) 
(extr[i*l].dir*-9)))) 



for (i-9;i<-15;i**) { 
arr x levela[ i]-PALSB; 
arr~y~levels[i]*PALSE; 

} 
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for iKextris ;!•♦) 

if ||(„tr[i3.dir«U4*CC„trCi-l].dir..71 II < extr[ 1 ♦ 1 ] . dir--0 ) ) ) 

j (extrCi] .dir«-3)H.( < extr[ i*l ] . dir--5) I I (extr(i*l ] .dir--l* ) ) ) 

( (extr[i] ,dir««l) LL (extr[i+l ] .dir»-5) ) || 
^ ( (extr[l].dlr--3) . && (extr(i*i ] .dir-»7) ) ) 

If ( (extr[i-l].pen s ta ♦extr [i] . pen sta)--2) 

{ 

arr_x_leveis[extr[i ] .x_cor] • TRUE; 
arr~y~levela[extr[i] .y~cor] ■ TRUE ; 

} 

} 

for (i-G; i<-15si**) { 

if <arr_x_levels[i]--TRUE> ( { (*reat) . f eat[l6] ) ; 
If (arr y_leveIa[i]--TRUB) U (*feat) . feat[17])**) ; 



for (l-G|K-15si + *) { 
arr_x_levela[i]-FALSE; 
arr~y~le vela [ i ] -FALSE ; 

} 

for ( i« 1 : Kextraa : ) 
If (•xtr[i].out rot--5) 
{ 

if ( (extr[i-l] .pen ata*extr[ I] .pen ata)-«2) 

{ 

(•feat) . feat[l8]** : 
arr_x_levels[extr[i] ,x_eor] ■ TRUE; 
arr y~levela [ex tr[ i] ,y~cor ] • TRUE; 

} 

} 

for (i»0;i<-15:i**) { 

if (arr x levels[i]«TRUE) ( ( { # feat ) . f eat[ 19] ) ; 
if (arr~y~le veil [i) "TRUE) ( ( < # f eat) . feat[20] ) ♦♦) ; 

} 



for (i-e;i<-i5;i**) { 

arr x levela[ i ]-FALSE; 
arrIyllevala[i]*FALSE; 

) 

for (I-ljKextrae;!**) 

If ( <extr[i] . out_rot- -3) || (extr[i] ,out_rot- -4 ) ) 

if ( (axtr[i-l] .pen ata*extr[i] ,pen_eta ) --2) 

{ 
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(♦feat) ,feat[21]**; 
arr_x_levela[extr[i J ,x_cor] ■ TRUE; 
arr y levels[extr[i ] .y cor] - TRUE; 

} 

} 

for (l-0;K-15;i**) { 

if (arr_x levola[i]--TRUE) ( ( { *feat) . reat[22] ) ) ; 
if (arr_y!levela[i]--TRUE) ((( # feat) .feat[23))**) ; 

} 



caleualtes the are features of a ayabol, 
(called froa cale_features) . 

void eale area (struct TABLE EXTRBMOMS extr[],int extras, 
struct FEATURES # feat) 

{ 

int i-0; 
int j-0: 

while (i<extras) 

if ( (extr[i] .in^rof-7) II (extr[i] . in_rot««l ) ) 

1 ( ('feat) .feat[24])**; 

while < (extr[i].in_rot«-7) II <extr[i] .in_rofl) ) i**; 

} 

> 

i-0; 

while (Kextras) 

if (axtr[i].in rot«7) 
{ 

J-i; 

while (extr[i].in_rot--7) {*♦♦;!♦♦;} 
} else if (extr[i].in_rof-l) 

{ 

while (extr[i].in_rot--l) (j**sl*+;> 
} ( (*feat) .featC25])-( ( # feat) . feet[25] ) ♦ U*t) { J/4) ; 

) 
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calculates the levels features (auibtr of diufferent levels) of a 
symbol 

(called from calc_f eatures ) . 

void calc syabol_levela (struct TABLE EXTREHOHS extr[],lnt extras, ^ 

struct FEATURES *feat) 



{ 



} 



Int i-0; 

boolean arr_x_levels[ 16 ] ; 
boolean arr_y_levela[l6 J ; 

for (i-e;i<-15;i**) { 
-arr_x_levela[i]"PALSE; . 
arr y~iovele[i]«FALSB; 

) 

for (i-9;i<-extrma ;i**) 
{ 

arr_x_levels[extr[i] *x_cor] • TRUE; 
arr~y~ievela[extrCi J .y~eor] • TRUE; 

> 

for (1-9: i<-15:i** ) { 

if (arr x level « [i ]--TRUE ) { ( < # feet) . feat[26]) ♦♦) ; 
if (arr~y~leveli[i]«TRUB) ( ( < • feet ) . feat[27] ) ) ; 

} 



calculates the number of minumuma/ maximums in X mad Y. 
(called from calc_f eatures) . 

void calc mist minmax (struct TABLE BXTBEMOMS extr[],int extrme, 

struct FEATURES *feet) 

{ 

int i; 

for ( i-1 ; Kextrms; i** ) 

if ( (extr[i-l] .pen_sts*extr[i] .pen_st«)--2) 

( if (((extr[i].dir«5)*4((extrti^l].dir«7) II 
(extrU*l].dir«6))> || 
((extr[i].dir«3)fcM<Mtr[i*l].dir«l) 1 1 
(extr[i*l].dir«-2>>) || 

( (extrCi].dir«5) " ( extr[i*l] .dir«l) ) || 
((extr[i].dir— 3) « ( emtr[i*l ] .dir--7) J ) 
(♦feat) .feat[47]**s 

if (((extrCi].dir«7)i*((axtr[i*l).dir«5) II 
(extr[i*l].dir«6))) || 

( (extr[i] .dir--l)14( (extr[i*l].dir«3) 1 1 
(extrCi*l].dir«2)) ) || 

((extr[i].dir— 1) 11 <extr[i*l] .dir— 5) ) || 
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( (extr[i].dir--7) " (extr[i*l] ,dir--3) ) ) 
(•feat) . feat[48)**; 

if (((extr[i].dir««7)*M <extr[i»l] • dir--l ) || 
(extr[i*l].dir--0))) || 

( (extr[i].dir«5UM (extr[i*l].dir— 3) II 
(extr[i*l].dir«4)) ) || 

((extr[i].dir«5) « ( extr[i*l ] . dir--l ) ) || 
(<extr[i].dir--7) (extr[i*l].dir--3)) ) 
(•feat) .feat[**9]**; 

if (({extp[i].dip--l)t4((«xtr[i*l].dip«7) II 
(extr[i*l].dir«0) ) ) || 

( (extr[i].dir«3)t*({axtr[i*i].dir--5) II 
(extr[i*l].dir--4)) ) || 

((extr[i].dir"l) tl (extr[i*l].dir~5)) II 
((extr[i].dir~3) " (extr[i*l].dir--7))) 
(•feat) .feat[50]**; 



} 

) 



' calculates the features of a syabol depending on the extreiun of 

that syabol . and fills in the structure variable: feat. 
««»•«•••••»••••••••••••••«••♦•••••••• ••••••••••••••••••••••••• 

void calc features (struct FEATURES *feat.int points. 

struct TABLB.BXTRBMOMS extr[]. 
lnt extras, in t feate) 

{ 

int ij 



/• initialization •/ 

for (i«0ii<MUM.PBAT;i**) ( # f eat ) . f eat[ i]-0 ; 

(♦feat) . reat[6] • featO ; 
(•feat) . feat[l] - points ; 
(•feat) .feat[2] • extras ; 

cale space_feat ( extr .extrae . f eat ) ; 
calc~rot Textr, extras, feat) ; 
calc~ext_typee (extr .extras • feat) s 
calc~aros (extr .extras , feat ) ; 
calc'tyabol levels (extr, extras, feat) ; 
calc~nua_alnaax (extr .extras, feat) ; 
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/• This aodule is for calculating and aanlpulatlnf extreauas , it 

includes four procedural : 

(1) cale_extreauaa : To find the extreauns of tha syebol , and 
the "change in pen" points. 

(2) f ind_aax_extre : To find the ■ax/aln X-coordlnate and the 
■ax/aln Y-coordlnate of the ayebol. 

(3) analyse_extreauas : A procedure to analyse the extreauas found 
so far, aalnly this procedure aerks close extreauas as 
suspeclous extreauas. 

(4) conv21evels : Replaces the actual coordinates of the 
extreauaa in arr_extreeuaa with the levela of these eoordlaatea 
by doing quantisation, (there are 16 levela). */ 

'include "aain.h" 



The input of this procedure is the array of coordlnatea which holds 
the coordinatea of the syabol , and the nuaber of these points , it 
fills the apecial of points (i.e. , extreauaa or change in pen) in 
the array 

arr extreauas , it returns the nunber of special polnta it found, • 
, 

lnt calc_extreaoaa (struct TABLB_BXTRBMOMS arr_extreaoas( ] , 

~ struct POINT~arr eor[ ] t lat~nua of points) 

{ " " 

unsigned lnt indEj 
unalgned lnt ndxj 
unsigned pen_ves_upi 
lnt crnt_quart t prev_quart ; 
int crnt_rot ,prev_rot: 
lnt Sx,Sy »PSx,PSy7a,b; 
lnt f irst_point-l ; 
lnt Pndx-6; 
unsigned lnt LastHdx; 
lnt 1; 
indB«6j 
ndx«G; 

pen_wns_up»l ; 

3x*9; " 

Sy-0; 

PSx-G; 

PSy«6| 

a«6ib-9; 

while (ndx<nus_of_pointa) 

while < farr cor[ndx] .pea_etatus ) «1 ) 

< 

if (pen_waa_up«l) 

( / # beginning eatreaoa •/ 

if (first poinfl) 

{ 

int tSx.tSyt 
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Sx«(arr_cor[ndx*l] . x_cor-arr_ cor[ndx] -x_cor) ; 

Sy- ( arr^cor[ndx*i ] . y_cor-arr_cor[ndx] ,y_cor) ; 

tSx» ( arr_cor[ndx*2] . x_cor-arr_cor[ndx*l ] . x_cor) ; 

tSy« ( arr_cor[ndx+2] . y_cor-arr_cor[ndx*l ] .y_cor ) : 

a-Sx # tSy-Sy # tSx; 

b-Sx*tSx*Sy*tSy; 

PSx-Sx; 

PSy»Sy ; 

} 

else { 

/• for the previous ENDINQ extreaom •/ 
Sx- ( arr_cor[ndx] . x_cor-arr_cor[Pndx] .x_cor) ; 
Sy- (arr"cor[ndx] . y_cor-arr_eor[Pndx] ♦y_cor) ; 
PSx* (arr_cor[Pndx] .x_cor-arr_cor[Pndx-l] .x_cor) ; 
PSy- (arr~cor[Pndx] .y2cor-arr_cor[Pndx-l J .y_cor) ; 
a«PSx # Sy-PSy*Sx; 
b-PSx*Sx*PSy # Sy; 
arr_extreaoBs[lndE] .p_ndx-Pndx; 
arr~extreao«s[indB] .x_cor»arr_cor[Pndx] .x_cor; 
arr~extreao«s[indE] .y_eor-arr_cor[Pndx].y_cor; 
arr~extreaoas[ indB] . pen_sts-G; 
arr~extre«o«a[indE] .dir-def_quart (PSx.PSy ) ; 
arr~extreaoa»[indE] .out rot-def_quart (b , a) ; 

{ 

int PPSx.PPSy; 

PPSx- (arr cor[Pndx-l] .x_cor-arr_cor[Pndx-2] .x_eor) ; 
PPSy»(arr~cor[Pndx-l] .y~cor-arr_cor[Pndx-2] .y_cor) ; 
a-PPSx # PSy-PPSy*PSx; 
b-PPSx # PSx*PPSy # PSy; 

arr extreaoa«[ indB] .in_rot-def_quart(b. a) ; 

> 

indB**; 
PSx-Sx; 
PSy-Sy ; 

{ 

Int tSx.tSy; 

Sx- (arr cor[ndx*l] .x_cor-arr_cor[ndx J .x^cor) ; 
Sy-(arr~cor[ndx*l] •y3cor-arr_cor[ndx] .y.cor) ; 
tSx-(arr cor[ndx] .x_cor-arr_cor[Pndx] .x_eor) : 
tSy(arr"cor[ndx] .y~cor-arr_cor[Pndx] .y_cor) ; 
a-tSx # Sy-tSy # Sx; 
b- tSx*Sx ♦ tSy # Sy ; 



} 



crnt_quart-def_quart(Sx # Sy) ; 

crnt^rot-def quart(b.a); 

arr extreao«a[indE] .p_ndx«ndx: 
arr~extreao«a[indE]*x_cor-arr_cor[ndx] . x.cor 
arr~extreaoB»[indE].y_cor-arr_cor[ndx].y_cor 

arr~extre»o«s[indB].pen_ata-l; 

if Tfirat point- -1) { 

arr extreaoas[indE] .dir«15 ; 

arr'extreiois [ indB] . in_ro t • 15 ; 

arr%xtre«oa»[indE] • out.rot-15 ; 
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ndx**; 

first point-6; 

} 

else { 

arr_extreaoas[ indE] . dir»daf_quart (PSx,PSy ) ; 

arr_extreaoas[indE] . in_rot*Q; 

arr ex trenoa«[ indE] . out rot-def quart(b.a); 

} " 

IndE** ; 
pen_wae_up"G; 
} else~{ ~ 

crnt_quart-def_quart (Sx.Sy) ; 

crnt_rot»def_quart (b t a) 3 

if (( <crnt_quart I -prev quart) || 
( (crnt_rot>»4) 44 (prev_rot<4 ) ) || 
({ernt rot<4) 41 (prev fot>-4)) 

) 

ftfc (prev.rot!«15) ) 

{ /• regular extreioi •/ 
IT ((aba(Sx)>e) Lk (abs(Sy)>e) || (b<0)) 
{ 

if ( ( ndx- 1 - arr_ex trtioai [ indB- 1 ] . p.ndx ) > 0 ) 

arr_ex treaoas [ indE ] . p_ndx«ndx-l ; 
arr_extreaoa«[indB] .x_eor»arr_cor[ndx-l] .x_cor; 
arr~extreaoes[ IndB] .y_cor«arr~eor(ndx~l] . y~eor ; 
arr~extreaoaa[indE] .pan_sta»l7 ~ 
arr~extreaoee(indB] »dlr*prev_quart % 
arr^axtreaoaa [ indE) • in_rot-prav_rot ; 
arr"extraaoaa[ indB] .out_rot«crnt_rot ; 
indE**; " ~ 

} 

} 

) 

ndx**; 

Sx»(arr cor[ndx].x_cor-arr_eor[ndx-l] .x_eor) ; 

Sy"(arr~cor[ndx].y_cor-arr_eor[ndx-l] .y_eor) ; 

a-PSx # Sy-PSy # Sx; 

b-PSx # Sx*P3y # Syj 

PSx*Sx; 

PSy«Sy; 

prev_quart*crnt_quart s 
prev rot s ernt rot; 
} /• and of while (arr_cor[ndx].penttatuf-«l ) •/ 
if .( (pen_waa_up*-6) it ( arr_cor[ndx-l] ,pen_etatua--l) ) 
{ /* ending extreaoa */ 
Padx«ndx-1; 
pen_waa_up-l ; 
LaatNdx-ndx-1 ; 

> 

ndx**j 

} /♦ Qdx<-«uaOfFointa */ 
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/* Add the last special polne to the array */ 
arr_extreaoas [lndE] . p_ndx*LastNdx ; 
arr^extreaoas [indE] . x~cor •arr_cor[ Las tNdx] mX cor; 
arr_extreaoas(indB] . y_cor»arr~cor[ Laa tNdx j .y~cor; 
arr_extreaoas[lndE] . pen_ata-oT ~" 
Sx«7arr_cor[LastWdx-l] .x_cor-arr cor[LastNdx-2] .x cor); 
Sy-(arr_cor[LaatNdx-l] .x_cor-arr"cor[LaatNdx-2].x"cor) ; 
PSx»(arr_cor[LastNdx-2].x_eor-arr_cor[LastNdx-3J.x cor) ; 
PSy*(arr_cor[LastNdx-2] . y_eor-arr_cor[ Las tNdx-3) .y~cor) ; 
arr_extreaoas[indB] .dlr*def_quart (Si, Sy) ; ~ 
a-PSx*Sy-PSy *Sx ; " 
b-PSx # Sx*PSy # Sy ; 

arr H extreeoas[lndB] *ln_rot«def_quart(b,a) ; 
arr_extreaoaa[indE] .out_rot"157 

return (IndE) ; 



/• # • 

This procedure is to find the aax/aia X-coordioate aad the aax/aia 

Y-coordinate of the syabol. 

void find_aax_extra (struct TABLE_EXTRE«OMS arr.extreaoasU , 

iat nua w of_extras t int *Xain # int *Xaax, 
int *Yaln,int •Yea*) 



< 



unsigned int i»0; 

♦Xain-1290: 
♦Xaajc-9; 
♦Yain-12Q9; 
♦Yaax-e; 

while (K-nua of extras) 
{ ~ " 

if ( arr_extreaoas[l] .x_cor<*Xaln) # Xala»arr_extreaoas[i] •x_cor; 

if (arr_extreaoas[i] .x~cor> # Xaax) *Xaax-arr"extreaoas[ 1 ] . x^cor; 

if ( arr_extreaoas[i] . y2cor<*Yain) *Yaln-arr~extreaoas[l] .y~eor; 

if ( arr~sxtreaoaa[i] .y~cor>*YaaJt) •Yaax»arr~extrsaoas[i] .y"cor; 

} 



correct dir t in_rot ,out_ rot for suspicious points v called froa 
aaalyae extreauas ~ 

• • / 

void correct extra (struet POINT arr cor[], 

struct TABLE BXTRENOMS extra[] t 

struct TABLB'bxTRENONS arr exe extra[] t 

int i.int Pi. int J) 

< 

int Sx,Sy t PSx ,PSy; 
int ndxl,ndx2; 
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int a.b; 

ndxi "extra [ Pi ] - p_ndx ; 
ndx2-ex trn[ i] . p ndx; 
if (POO) 
{ 

if (extrn[Pi-l].pen 3ta--0) 
{ " 

PSx-arr_cor[ndxl].x_cor-arr_cor[extra[Pi-l]. p ndx],x cor- 
' PSy-arr.cortndxlJ.y^cor-mrr.corCextrBCPi-lJ.p^ndx] .y~cor| 

elae { 

PSx-arr_cor[ndxl] .x.cor-arr eor[ndxl-X ] . x cor; 
^ PSy«arr_cor[adxl] .y_cor-arr2cor[ndxl-i].y2cor; 

} else {PSx"0;PSy«0: ) 

Sx»arr_cor[ndx2] .x_cor-arr_eor[ndxl ] .x_eor ; 
Sy«arr_eor[ndx2] .y_eor-arr~eor[ndxl] .y~cor; 
a-PSx*Sy-PSy*Sx; " ~ 

b»PSx # Sx*PSy # Sy ; 

if (arr_exc_extra[J-l].out_rot! »15 J 

arr_exc_ex tra[ j -1 ] . ou t_ro fdef _quert { b . a) j 

PSx-Sx; 
PSy»Sy; 

arr_exc_extra[ j ] .dir-def _qusrt ( PSx ,PSy) ; 

arr_exc_extra[ J ] .in rot-0; 

if (arr_exc_extra[ j"J.out_rot 1-15) 

if (extra[i] .pen sts*-8) 

{ 

Sx-arr.cor[extPi[i*l] .p^ndx] .x_cor-arr cor[ndx2].x cor; 
Sy- err_cor [ext ra[i ♦ 1 ] . p_ndx ] . y_cor-arr_cor [ndx2 ] • y~cor ; 

else 

{ 

Sx«arr_cor[ndx2+l ] . x_cor-arr_cor[ndx2 ] . x_cor ; 
Sy • arr_cor [ ndx2* 1 ] . y_cor-arr_cor [ ndx2 ] . y~cer ; 

a-PSx*Sy-PSy*Sx; 
b-PSx # Sx*PSy*Sy; 

arr axe extra[J].out rot-def quart(b,a); 

} 



A procedure to analyse the extraiust found so far f aalnly this 
procedure aarks cloae extreauea as suspecious extreauea. 



int analyse extreaoas (struct POINT arr_cor[]. 

struct TABLB.EXTRBMOMS extre[], 

struct TABLB_BXTRBKOIIS arr_exc_extra[ ] . 

int dui of extras) ~* 

{ 

int i.j-e? 
int count-©; 
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int Pi-G; 

boolean FirstP-TRUE: 

For (i-l;i<nuo of extrnsii^) 

{ " " 

if ( ( (extrm[i].x_cor-extrm[i*l].x cor)<2 || 
(extrm[i] .y_cor-extra[i ♦ 1 ] . y cor)<2) LL 
(extrm[i] . in_rot ! -extrn[ i*l ]7in_rot ) LL 
(extrm[i] .dir«extrm[±*l] .dir) 44 
(extrm[i] «pen_ats«l ) 44 

(extrm[i-l] .pen_atsl-0) ) extrn[ij . suap-l ; 
else {extra[i] .susp-0; count** ; } 

extra [0] . susp-0 ; 
extra [1] . susp-O; 
/•count** ; •/ 

for (i-G; i<-nua_of_extrns ; i*+) 



If (extrm[ i] . SU3P--0) { 

arr_exc_extm[J] . p_ndx-extra[i ] .p ndx; 
arr_exc_extra[ j ] . x_cor-extra[i ] .x"cor; 
arr_exc_extra[ j ] . y_cor-extra[i ] .y~cor; 
ar r_exc_ex t r«[ j ] . penj ts -ex t ra [ i ] Tpen 8 ta ; 
arr_exc_extra[ j] . dir-extra[ i ] . dir; 
arr^exe^extrnUl.in^ot -extra[i].in rot; 
arr_exc_extrm[ j ] .out rot- extra[i] . out rot; 
if (FlratP- -FALSE) 
{ 

correc t_ex t ra ( ar r_cor f extn f 
arr_exc extra , i ,Pi7j ) ; 
FiratP-TRUE; 

} 

if (extra[i] .pen ata--0) Firs tP •TRUE; 

) 

else { 

If (FirstP) Fl-1-1; 
FlratP-FALSB; 

) 

> 
{ 

/•FILE m tp; 

fp-fopen ( "extra. out* f "ab^" ) ; 

for ( 1-9; K*eount;i + * ) 

{ 

fprintf (fp,"JSd %& td %d td td td \n". 
ar r_exc_ext ra [ i ] - p_ndx « arr_exe_extra [ i ] . x_cor , 
arr_exc_extra[i] . y_cor . arr_exc_extra[i ] . pen_ats » 
arr~exc~extra[i] . dir f arr_exc_extre[i] . in_rot , 
arr axe extra[i].out rot); 

T 

fprintf (fp. ## * ## •••• Nn . ) . 

fcloae (fp); # / 
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> 

fiturn (count) ; 

} 

/ '•• 

Replaces the actual coordinates of the extrenuaj in arr_ex tremums 
with the levels of these coordinates by doing quantization , ( there are 
16 levels) .It also calculates featO : I.e. the relative size of 
syabol-32*div round (Xwidth , Yvidth ) . 



void conv21evels (struct TABLE_BXTREMOM$ arr_extreaoasC] . 
lot tius of extras t lnt # feat0) " 

( 

int x_wldth,y_wldth; 
lnt Xaln.XaaxTYaln, Yaax; 
int i-G: 

f ind_aax_ex tra ( arr_ex treaoas , nua_of _ex tras , iXaln # &Xaax » iYaln , tYaax ) : 

x wid th-Xaax-Xain ; " ~ ~ 

y'width-Yaax-Yain; 

while (K«nua of extras) 

{ " " 

arr extreaoas[l] .x cor«div round ((arr extreaoas [1] .x cor* 

Xaln) # ORID t x_width); 
arr extreaoas[i] .y cor«div round ((arr extreaoas[l] «y cor- 

Yaia)*GRXI> 9 y width)} 

) 

( # feate)«div round (50 # x width. y_wldth ) ; 
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^include 



isin.h" 



{ 



void print_features (itruct FEATURES # feat.char filenaae[]) 

FILE *fp; 
lot 1; 

fp*f open (fllenaae, "ab*" ) ; 

/•fprintf (fp f "naae of syabol «Xs\n" . ( # feat) . IDfeat) ; 
fprlntf (fp."size of aynbol **d\n" , { • f eat ) . f eatO) ; 
fprintf (fp/nuabtr of points -%d\n" , ( # f eat ) . f eatl ) ; 
fprlntf (fp,"nuiber of itr «2d\n" , ( *f eat ) . f eat2 ) ; 
fprintf (fp, "nuaber of spaces -Xd\n" t ( *feat ) . Teat3 ) ; 
fprlntf (fp, "nuaber of dlff. levels in X for end of 

spaee-*d\n" , ( # feat) • feat**) ; 
fprlntf (fp, "nuaber of dlff. levels In Y for end of 

space-*d\n" . ( # feat) . feat?) ; 
fprlntf (fp, "nuaber of spaces for q<4 -*d\n". (•feat) . feat6) ; 
fprlntf (fp, "nuaber of spaces for q>«4 -*d\n" , ( # feat) -feat8) ; 
fprlntf (fp, "nuaber of spaces ro<4 

•*d\n", ( # feat) .feat73) ; 
fprlntf (fp/nuiber of spaces ro>-4 

•*d\n". ( # feat) .feat75) ; 

fprlntf (fp, "nuaber of linear strokes 

•*d\n", (•feat) .featie) ; 
fprlntf (fp, "nuaber of linear strokes where dlr<*t 

-*d\n". ( # feat) .feat69); 
fprlntf (f p. "nuaber of linear strokes vhere dir>-4 

-Xd\n" , ( # feat) •feat7D ; 

fprlntf (fp, "nuaber of strokes with pos. rot 

•*d\n", (*feat) .featll) ; 
fprlntf (fp, "nuaber of strokes with neg.rot 

-Jd\n" , (•feat) . featl2) ; 

fprlntf (fp. "nuaber of strokes ro<4 

-*d\n", (•feat) .feat!3) ; 
fprlntf (fp, "nuaber of strokes ro>*4 

•Zd\n" . (•feat) .featl5) ; 



fprlntf (fp, "nuaber of Ext In X neg. rot* 

«Xd\n" . (•feat) . featl7) ; 
fprlntf (fp,"diff. levels In X for ainX 
fprlntf (fp,"diff. levels In Y for alnX 

fprlntf (fp, "nuaber of Ext In X pos . rot. 
fprlntf (fp,"diff. levels In X for aaxX 
fprlntf (fp,"dlff. levels In Y for aaxX 

fprlntf (fp, "nuaber of Ext In Y neg. rot. 
fprlntf (fp,"diff. levels In X for alnY 
fprlntf (fp."diff. levels In Y for alnY 



■Xd\n", ( # feat).featl8) j 
-Xd\a" , (*feat) . featl9) ; 

■*d\n" , (*feat) . feat20) ; 
■*d\n". (•feat).feat21); 
«*d\n" . (*faat) . f aat22) ; 

-Xd\n" . (*feat) . feat29) ; 
■*d\n" , ( # feat) . f eat33) ; 
-Xd\n" . ( # feat) . faatBl) ; 



fprintf (fp, "nuaber of Ext la Y pos. rot. -Xd\n" , ( # feat) . f eat32) ; 
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fprlntf (fp.-diff. lavala In X for aaxY -*d\n a , ( # faat) . raat33) ; 
fprlntf (fp,"dlff. lavala In Y for auY -Sd\a a ,(*r««t).r«at3%)i 

fprlntf (fp,"nunbar of ext XT for nag. rot>Xd\n a , (°faat) .foatll) ; 
fprlntf (fp. "dlffarant lavala In. X for axt XY-neg.rot 

•Xd\n" . (Teat) . feat*2) ; 
fprlntf (fp, "dlffarant lavala In Y for axt XY-nag.rot 

•ld\n-,Craat).feat*3) ; 

fprlntf (fp.'nuabar of axt XY for poa. rot 

-|d\n" . ("feat) .faatM) ; 
fprlntf ( fp, "dlffarant lavala. In X for axt XY-poa.rot 

•M\n" . Cfaat) . faat«5) I 
fpslntf (fp, "dlffarant lavala In Y for axt XY-poa.rot 

•Sd\n" . (Vaat) . faat%6) i 

fprlntf (fp,"nuaber of are parta ■X»d\n a , (*faat) . faat65) t 

fpriatf (fp.'nuabar of elrelo parta -X.d\a", (*faat).faat66)i 

fprlntf (fp.'nuabar of dlffarant X-lavaU -*d\n a .(*foat).foat67)s 

fprlntf (fp,"nuabar of dlffarant Y-lavala *Sd\n" , (*faat) . faat68) t 



fprlntf (fp.'aua of aquara weighta 

■jtd\n" . <*faat) .aua_aqr_vgt) %•/ 

fprlntf <fp."\n*a\a a , (*faat) .IDfaat) i 
for (i-8U<HUII_PBAT|l**) 

fprlntf (fp, a %3d-.( # faat).faat[l])s 

If ((1—29) || (1"*8)) fprlntf (fp. a \n a ); 

} 

feloaa (fp)t 

} 
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fincluda "nln.h N 

lnt tranafora(char infile[30] , struct FEATURES *feat) 

struct POINT arr_cor[MAX_NUK_OF_POINTS] ; /• array of coordinates •/ 
struct TABLE_EXTREHOMS arr_ext reaoas [ MAX_NUM_OF_EXTREMOMS ] ; 

/* array of special points (i.e. extreauas 9 changing of pen 
position •/ 

struct TABLE_BXTREHOHS arr_exc_ex tras[MAX_NUM_OF_EXTREMOHS] ; 

/• array of excluded extraauas , it la excluded froa the array 
of extreauas by excluding close pointa */ 

int featQ; 

lnt nua_of_polnte,nua_of_extras • exc_nua_extraa ; 



Reading a file and calculate the nuaber of points for the ayabol,and 
stores the points read in the array : arr eor . 

/ 

nua_of_polats»read_polnts (arr_cor ,inflle) ; 
if Tnua^o f _p o in t a • ■ 0 ) return (6); 

/ • 
Calculates the extreauas froa the array of coordinates , aad stores 
it in the array t arr_extreauas . the function returns the nuaber of 
extreauas it calculated , and it la stored in nut of extrae. 

•••••••• •MtiMfMlttfifttittiiii/ 

aua_of_extrae»calc_extreaoae ( arr_extreaoas • arr_cor,aua_of_pointe) 3 

Replaeea the actual coordinates of the extreauas in arr_extreaoas 
with the levels of theaa coordinates by doing quantisation, (there 
are 16 levels) 

.•• # •#•••##•#•##••••••#/ 

. conv21evela ( arr_extreeoae,nua_of_extrae ,lf aatO) 5 

/ 

Bxcludea cloae points in the extreauas array and atorea the reaainlng 
extreauas in arr_exc_extras . it raturna the nuaber of extraauaa left 
after excluding*" " 

••••»•••*• ♦ / 

exc_nua_extraa - analya e_ex t reaoaa ( arr_cor , arr_ex treaoaa , 
arr_exc_extrae , nua_of _extraa ) ; 



calculates the featurea of the ayabol , and storaa it ia the atructure 
variable feat* 

•/ 

ealc faaturaa 

( 4 ( T f eat ) , nua_of .points , arr_exc_extra* , exc_nua_ex tras , f ea te ) ; 
return (nua of.polnta); 

) 
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#include •■ain.h" 

/ 

a procedure to update the ilniaui and aaxiaua Haiti of a syabol t 

according to features of entered symbol (i.e. : feat) 



void calc_liaits (struct FEATURES *min_f eat t struct FEATURES # aax feat, 

struct FEATURES feat) 

{ 

int i; 

for ( i • 0 ; i < NUM_FEAT ; i ♦ ♦ ) 

if ( (feat.feat[i])<(( # ain feat ) . feat[i] ) ) 

( (•min_feat) .feat[i]) -7f eat. feat [i]) ; 
if ( (feat. feat[i])>{ ( # aax_f eat) .feat[i])) 

( (*aax feat) .feat[i])-( feat. feat[i]) ; 

} 

> 

/ • * ••••• 

Saves ainiaua and aaxiaua features of a syabol do disk (i.e. spaces 
files) 

• * / 

void 3ave_ain_aax (struct FEATURES ain_feat, 
" " struct FEATURES aax feat) 

{ 

FILE # fp; 

char space[8] ,Cteap[8] ; 
iat teap; 

strcpy ( space • "space" ) ; 
teap-aln_f eat . feat[3]; 
itoa ( teap ,C teap ,10 ) ; 
street (space.Cteap) ; 

if { ( f p-f open ( space , "ab*" ) ) 1 •NULL) 

fwrlte (*ain_feat,aiseof (ain_feat) . l.fp) ; 
fvrlte (4aax~feat,aiseof (aax_faat ) , I , fp) ; 
fclose (fp) ; 

) 

> 
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#include <s tdio .h> 
# include <s tdlib.h> 
^include <math.h> 
# include <conio #h> 
# include < values .h> 
^include <mem.h> 
^include <string.h> 
#include < process .h> 



^define GRID 15 

#define MAX_NUM_0F POINTS 100G 
#define MAX_NUM 0F~STR0KES 64 
^define MAX NUM~0F EXTREMOHS 32 
#define NUM_FEAT 53 
#define NUM_SYMBOLS 72 
^define DIVISER 6 
#define TRUE 1 
#define FALSE 0 



typedef int boolean; 

struct TABLB_STR0KES_NEW { 
unsigned strk_nuo ~ 
int delta_x 
int delta~y 
unsigned lenght 
unsigned pen_status 
int rotation"" 

}; 

struct POINT { 

unsigned x_cor : 10; 

unsigned y~cor : 10; 

unsigned pen status : 4; 

}; 

struct TABLEJEXTREMOMS { 
unsigned p_ndx : 10; 
unsigned x_cor : 10; 
unsigned y_cor : 10; 
unsigned pen_sts 
unsigned dir 
unsigned in_rot 
unsigned out_rot 
unsigned susp 
unsigned reserve 

}; 

struct FEATURES { 

char IDfeat[ll]; / # Id feature for naie */ 
unsigned int f eat [NUM_FEAT] ; 

}; 
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feat[0] 
feat[l] 
feat[2] 
fcat[3] 
feat[4] 
r«ac[5] 

feat[6] 
f«at[7] 
feat[8] 

faat[9] 

feat[10] 

foat[ll] 

feat[12] 
feat[13] 
feat[l4] 

feat[15] 
feat[l6] 
faat[17] 

feat[l8] 
f«at[19] 
feat[26] 

faat[21] 
feat[22] 
faat[23] 

feat[24] 
feat[25] 
feat[26] 
feat[27] 

feet[28] 
feat [29] 
faat[30) 

faat[31] 
faat[32] 
faatC33] 
faat[3*] 

f«at[35] 
f«at[36] 
faat[37] 
faat[38] 

faat[39] 
fest[4Q] 
feet[4l] 
feat[42] 



relative size of syabol 32*div_ a rouhd(Xwldth. Ywidth ) 
nuiber of polnta 
nuaber of atrokes 
nuiber of apacaa 
nuaber of different levels in X 
nuaber of different levels In Y 



for end or space 
for end of space 



nuaber of Bxt X in neg.rot 
different levels in X for alnX 
different lavala in Y for ainX 

nuaber of Bxt In X poa.rot 
dlffarent levels in X for aaxX 
diffarent levels in Y for aaxX 

nuaber of Ext in Y nag. rot 
different levels in X for alnY 
different levels in Y for alnY 

nuaber of Bxt In Y poa.rot 
different levels in X for aaxY 
dlffaraat levels in Y for aaxY 

nuaber of BxtXY for neg* rot 
dlffarent levels in X for feat 41 
dlffaraat lavala la Y for faat 4l 

nuaber of BxtXY for pos. rot 
different levels in X for feat 44 
different levels in Y for feat 44 

nuaber of arc parta 
nuaber of circle parta 
nuaber of X-levels in syabol 
nuaber of Y-levela in syabol 

nuaber of linear strokes {in_rot-»0) 
nuaber of pos. rot* strokes Tln_rot->l) 
nuaber of nag. rot. strokes (in2rot««7) 

nuabar of linasr strokes where dir-e.l 

nuaber of linear strokes where dlr*2,3 

nuaber of linear strokes where dir-4,5 

nuaber of linear strokes where dir-6.7 

nuaber of strokes where out_rot«0,l 
nuabar of atrokes where out_rot«2.3 
nuaber of strokes where out_rot«4,5 
nuaber of strokes where out~rot"6,7 



uaber of spaees where q*0.1 

uaber of spaces where q*2.3 

uaber of spaces where q-4,5 

— ______ *~ k _ — _ _•£ 7 



nuaber 
nui 

nuabar of spaees where q*6 f 7 
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feat[43] ■ nuaber of spaces where out_rot-0.1 
feat[44] • nuaber of spaces where out_rot-2.3 
feet[45] • nuaber of spaces where out~rot-4,5 
feat[46] ■ nuaber of spaees where out~rot-6,7 

feat[47] ■ nuaber of aln X, 

feat[48] - nuaber of max X. 

feat[49] - nuaber of aln Y. 

feat[50] ■ nuaber of tax Y. 

feat[51] * sua length of spaces. 
feat[52j - relative position of spaces. 
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/• MAIN FOR RECOGNITION 



•/ 

^include "nain.h" 
^include <stdio.h> 

/ # 

The program reads the file temp.ltr fron the disk . and calculates 
the aatchlng probability for every symbol to the symbol defined in 
the file teap.ltr t and then stores the vector of probabilties for 
all symbols in the file data. in . 

•/ 

void nain( ) 
{ 

FILE # fp ; 

struct FEATURES feat; 
struct FEATURES ein_feet; 
atruct FEATURES eax^feat; 

/• Vector of probabilties , for each syabol ve calculate that the 
aatchlng probability between it and the syabol defined in 
teap.ltr •/ 
struct { 

char naaeC9] ; 
int prob: 
) vector[NUM_SYIIBOLS]; 

int index; 
int spaces«G; 
int prob-9; 
char f llenaae[ll] 
char Snaae[8] ; 
char Cteap[10]; 
char spacef ile[ll] ; 
char lnflle[ll]; 
int 1; 

int n_sp_aya-9; 

systea ("del feat. out"); 

for (i-G;i<-MUII SYMBOLS ; 1** ) 

{ 

char Syatfaae[26]; 
char Cteap[8]; 

strcpy (SyaNaae, "aya" ) ; 
itoa (i.Cteap, 19) ; 
street (SyaNase.Cteap ) ; 
street (SyaNaae, " . ■ ) ; 
atrcpy(vector[l] . nane , SyaNaae) ; 
vector[i] . prob-6; 

) 
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atrcpy ( f ilenaie , " teap . 1 tr" ) ; 
strcpy (infile.filenaae) ; 

/* get features of syabol in file: infile •/ 
tranafora (infile, tfeat) ; 
atrcpy ( feat . IDfeat , infile) ; 

spaces -f eat . feat[ 3] ; 
itoa (spaces .Cteap, 10) • 
atrcpy ( spacefile , "space" ) ; 
•treat (spacefile. Cteap) ; 

' # ;S. a p C :i£V blCh COr "' POnd8 t0 «^ol. r.pr...nt.d in th. 

if ( (fp»fopen(spacefile, "rb*") ) i-Nl/LL) 

/• for every syabol with the aaae nuaber of spaces set einiaua 
and aaxlaua features •/ *oc amiaua 

while ((freed ( K.in.f eat) # eiaeof (ain^feat ) 1 f f p) ) >©) 

freed (fc(aax_feat) f sizeof <aax_feat) .1, fp) . 
n_sp_aya**; 

/ calcualte the probability of recognition of ayabol •/ 

strcpy(feat. IDfeat. Bin feat. IDfeat) ; 
print_features(fcfeat f "feat. out" ) ■ 
atrcpy ( feat .IDfeat, infile) | 

prob-rec ( f eat,ain_f eat ,aax feat); 

/• fill the probability ik the appropriate index in the 

vector of probabilities for all the syabols •/ 
for (index-e;index<-NUH_SYMBOLS;index**) 

if (etrcap(ain_feat. IDfeat , vector[index] .naae) « 0) { 
vector[ index] .prob - prob ; 
break; 

} 

} 

^ f close (fp); 

/• Save vector of probabilities to disk •/ 

fp-fopen ("data. in" ,"*♦") ; 

for ( index-0 ; index <NUM_SYMB0LS ; index** ) 

fprintf (fp.,"*d Id\n" t index.vector[ index] .prob) ; 
fcloae ( fp) ; 



•xit (G); 

} 
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^include "oatn.h" 

/• This procedure is to read the points of the synbol fron a file , and 
fill it in the array of coordinates : arr cor. 

*/ 

int read points (struct POINT arr cor[],char *filenane) 

{ 

FILE # fpointer; 
unsigned int x,y,p; 

unsigned int prev_x , prev_y , prev_pen ; 
unsigned int i*0,in«O; " " 

f pointer-f open ( filename f " r*" ) ; 

prev_x«0; 
prev_y*0; 
prev pen*G; 

while ( (fscanf ( f pointer f "*d %d %6" .kx.ky ,tp)>0) 14 (p--G)); 
while (fscanf ( f pointer , "JCd %d %&" f 4x.4y t 4p) > 0) 

{ 

if (±n/DIVISER # DIVISER • • in) { 
in** ; 

a r r_c o r [ 1 ] . x_c o r- x ; 
arr_cor[i ] • y_cor«y ; 
arr~cor[i] .pen_status»p: 

if T( ( abstprev^x-x) ♦abs(prev y-y))>3) || (prev penl-p)) { 

prev_x»x; 
prev^y-y; 
prev pen«p; 

} 

) 

else in**; 

} 

arr_cor[i] .x_cor*arr_cor[i-l] .x_cor; 
arr"cor[i] •y^cor-arr^corfl-l] iy^cor; 
arr~cor[ i ] . pen_s tatus-0 ; 



f close ( f pointer) ; 
return (i); 

> 
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fi» T !?l? ■ odu J« general purpose procedure, which are 

(1) def_quart : a funtlon that reclevea tt "men are 



the quarter of th.„ twe^.i^r^ t'he rT S l"r r9tVna 
(2) dlv round : a function to calculate the round nu.ber*of th« 
divi-ion of two Integer nuxbers 8er or the 



'Include "nain.h* 



A funtlon that recleves two nuabers and .... 
^.these^two^nu.bers^in^ the range of 0-7. ret "« «• quarter of 

int def_quart (x.y) •••••••••••••• 

Int xi 
int yj 
{ 

if ((x>0 ) 4& (y-9)J return (0); 

if <<x>0 ) tt (y>6) ) return (1),- 

if ((x«6) tL (y>0) ) return (2): 

if ((x<6 ) It (y>6) ) return (3); 

if <{*<© ) &4 <y«0)) return (*): 

if (<x<Q > It (y<0) ) return (5): 

if (<x«0) t& (y<e) ) return (6): 

if <(x>6 ) It (y<e) ) return (7); 



return (15); 



...Jss:f«!;2:5h:- ewr " tha ^ou,M, BU ' b * P of th * * ivl ' l0B of two 

int div_rouad (int a. int 15) 
int i-0: 

int teapl,ceap2; 

teapi-a? 
teap2»b; 
a-abs(a) ; 

if (b«9) raturn (NAXINT) ; 
while(a>b) 

{ 

if (b>6) a--b; 
alaa a**b; 

} 

if ((a*a)>b) i** : 

if (((taapl>0) LL (teap2>0)) || ((teapKO) <U (taap2<9))) 
else return (~i); 
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#lnelude "aaln»h" 

/ • 

calcualtes the space features of a syabol , (called froa 
calc_f eatures ) • 

f 

void calc_space_feat (struct TABLE EXTREMOMS extrM.int extras 

struct FEATURES # feat) 

{ 

int i-G; 

boolean arr_x_levela[ 16] ; 
boolean arr_y3levela[ 16] ; 
unsigned lnt sua-0; 

for (l-e;K-15;l**) { arr_x_levels[i]-FALSB; 
arr_y levels [1 ] -FALSE ; 

) 

for ( i»9; Kextras ) 
{ 

If (extr[i].pen sts»«9) 
{ 

(•feat) .feat[51]-(*faat) .feat[51]* 
(extr[i+l] .p_ndx-extr[i] .p_ndx) ; 
sua*-extr[i] . p ndx; "~ 
((•feat) .feat[3]**) \ 
err.x^levelsCextrCi^i] .x_cor]«TRUB; 
arr y levels[extr(l*l] »y~cor ]-TRUE; 
switch <extr[l*l] .dlr) {"" 

case G : (*f eat ). featC39]** X break; 

eaae 1 : (*f eat ) • f eat[393++ ; break; 

case 2 : ( # feat) *feat[4e]+*; breek; 

case 3 : (*feat) .feat[40j**; break; 

case 4 : ( # feat ) . feat[4l ]♦♦; break; 

caae 5 : (*feat ) . feet[4l]*>; break; 

case 6 ; (*feat ) . feat[42]++: break; 

case 7 s ( # feat ) . feat[42]**; break; 

default: break; 

) 

> 

} 

(•feat) . feat[52]-dlv_round(8 # aua. ( # feat) .feat[l3) ; 

for (1-0;1<-I5;i**) { 

If (arr x^levels[l]--TRUE) < ( (»feat) .feat[4])**) ; 

If (arr~y levels[l]«TRUB) ( ( ( # f eat ) . feat[5] ) ♦♦) ; 

) 
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/ • 

calcuaites the rotation features of a symbol , (called fro 
calc_f ea cures ) . 



void calc_rot (struct TABLE EXTREMOMS extr[],int extras 
struct FEATURES # feat) 

{ 

int i; 



for ( i»l ; i< -extras ; i** ) { 
switch (extr[i] .in_rot) { 
case 0 : ( 

((•feat) . feat[28])**; 
switch <extr[i].dir) { 
case 0 : ( *f eat ). feat[31 ]♦♦; break 
case 1 : ( # f eat ) . f eat[31 J : break 
case 2 : ( # f eat ). feat[ 32 ]♦♦; break 
case 3 : (*feat) . feat [32] break 
case k : ( V eat ). feat[33J** : break 
case 5 : ( *f eat ). feat [ 33 )♦♦? break 
case 6 : ( # f eat ). feat[ 34 ]♦♦; break 
case 7 : ( *f eat )• faat[3<l ]♦♦; break 



default: break; 



} 



) 



case 1 : { ( # f eat ) . f eat[29] ) : eak: 
case 7 : { ( *f eat ) . f eat[36] ) ; break; 
default: break ; 

} 

if ( (extr[i-l] .pen sts*extr[i] .pen sts)--2) 

{ 



switch (extr[l].out_rot) ( 
case 0 : ( *f eat ) . 7 eat[35 ]♦< 
case 1 : < *f eat ) . f eat[35 ]•« 
case 2 : ( # feat ) . f eat[36]*< 
case 3 : ( # f eat ) • f eat[36]»< 
case 4 : ( *f eat) • f eat[37]*< 
case 5 : <*feat ) . feat[37]*< 
case 6 : ( *f eat ) . f eat [38] ♦« 
case 7 : ( *f eat ) . f eat[38] ♦ < 
default: break; 



break; 
break; 
break; 
break; 
break ; 
break; 
break : 
break ; 



if ( (extr[ 1-1] .pen sts*extr[ i ] . pen sts) 

{ 

switch (extr[i].out rot) 
{ 

case 0 : ( *feat ) . f eat[*» 3 ] ♦ * : 
case 1 : ( # f eat ) . f eat[<*3 ] ; 
case 2 : ( *feat ) . feat[44]*+ ; 
case 3 : ( # f eat ) . f eat[ 44 ]♦♦ ; 
case 4 : ( # f eat ) . f eat[45 ]♦♦ ; 



•1) 
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case 5 > I *feat ) . f eat[45] ♦ ♦ ; 
case 6 : ( # feat) , feet[46]**; 
case 7 : ( *f eat ) . f eac[46] ; 



calcualtes the extreaua type features or a syabol, 

(called froa calc_features) • 



void calc_ext_ types (struct TABLE EXTRBNOHS extr[],int extras, 

struct FEATURES •feat) 



{ 



int i-G; 

boolean arr_x_levels[l6] ; 
boolean arrZy~levels[l6] ; 

for (i»0ji<-15:±**) { 
arr_x_levele[i]-FALSB; 
arr~y~levels [i] -FALSE ; 

} 

for (1-1 ;i<extrat ;!*♦) 

if {{{extr[i].dir--3)44((extr[i*l].dir~l) || < extr[ 1*1 ] .dir--2) ) ) 

extr[i].dir--7)44<(extr[i«l].dir--5) II (extr[i*l ] . dlr«6) ) ) ) 

If { <extr[i-l] .pen sts*sxtr[i] .pen sts)--2) 
(*feat) .feat[6]*+; " 



ror (i-6;i<-15 { 
arr x levels [1 ] -FALSE ; 
arr"y"levels [ 1 ] -FALSE i 



} 



for (i-1 ; Kextras ; !*♦ ) 



if 



j (extr[i].dir--5)44( <extr[i*l] .dir-« 7) II { extr[ 1*1 ] . dir--6) ) ) 
extr[i] .dlr--3)44((extr£i*l].dlr"l) | | (extr[i*l] .dir«2) ) ) 



extr[l] .dlr— 5) 44 (extr[i*l] ,dir»l) ) || 
extr[i] .dir«3) 44 (extr[i*l].dir«7) ) ) 



if { (extr[i-l].pen_sts*oxtr[i].pen_sts)» 2) 



arr_x_levels[extr[l] .x_cor] » TRUE; 
arr^yllevelsCsxtrCi] •y^cor] ■ TRUE; 



SUBSTITUTE SHEET 



WO 94/09447 



PCT/US92/08703 



- 78 - 

for (i-0;i<-l5:i**) { 

if <arr_x_levels[i]— TRUE) ( ( (*f eat ) . feat [7] ) ) ; 
^ if (arr_y_leveis[i]— TRUE) ( { < # f eat ) . f eat[8] ) ♦♦ ) ; 

for (i-G;i<-15;i**) { 1 
arr_x_levels[i] -FALSE; 
arr~y~levela[i]«FALSE; 

} 

for ( i-1 ; i<extraa ; i**) ^ 

if j j(extr[i],dir— l)44<(extr[i*l].dir— 3) M (extr[ fl ] . dir— 2) ) J 

^ ((extr[i].dir«5)44<(extr[i»l].dir— 6) || (extr[i*l] .dir— 7) ) ) ) 

if ( (extr[i-t ] .pen a ta*extr[i] . pen ate)— 2) 
{ " 
({•fe«t).feat[9]**); 
arr_x_levels[extr[i] .x w cor] • TRUE; 
arr_y_levela[extr[i].y~cor] * TRUE; 



for (i-9;i<-15;i**) { 
arr x levela[i ]-FALSE ; 
arr~y~le vela [ 1 ] -FALSE ; 

} 

for ( i-1 ; Kextras : i** ) 

if ({extr[±].dir— 7)44((e*tr[i*l].dir—5> I I <extr[fl] .dir— 6) > ) 

extr[i].dir— l)44((extr[i*l].dir— 3) || (extr[i*l ] . dir— 2) ) ) 

extr[i].dir— 1) 44 (extr[i*l J .dir— 5) ) I I 
{(extr[i].dir« 7) 44 ( extr[ i*l ] .dir— 3) ) ) 

if ( ( extr[ i-1 ] .pen_ata*extr[i] . pen_ata) --2) 

arr_x_level»[extr[i] .x_cor] • TRUE; 
arr~y~level«[extr[±].y~cor] - TRUE; 

) 

) 

for <i-9;i<-15sf> { 

if (arr x levela[ i] — TRUE) ( ( ( # feat ) . f eat[ 10] ) ; 
if (arr~y~levele[i]« TRUE) ( ( ( # f eat) . f eat[ll] ) ) ; 

} 

for <i-9;i<«15:i**) { 
arr x levele[i]»FALSB; 
arr"y"levela [ i J-PALSE j 

) 
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ror (i-1 ;i<Bxtr««;l**) 

if jj(«*tr[i].dir--5)4K(extr[i*l].dir-.3) J| <extr[i.l] .dir«* ) ) ) 

((«xer[i].dir-l)tl,((extr[i*l].dir--7J || (extr[i*l J .dir--e) ) j ) 

if ( («xtr[i-l].pen_st»*extr[i].pen ats)>-2) 
Cfeat).fB.tCl2]**! 



for (i-6ii<-15:i«.*) { 
arr_x_leval«[i]-FALSE; 
«r_y_X«vel«[i]-PALSBj 



for (i»l ;i<extrx«;i*«) 

"II "' 



(•xtrCi].dir«7)t4((«xtr[fl].dir«l) || (e«tr[i*l ] .dlr--9)) ) 
axtr[i].dir--5)ii{(extr[i*l].dir--3) || (e*tr[i*l] .dir«4> )) 



> 



(extr[l].dir«5) tt (extr[i*l] .dir«l) ) It 
<<extr[i].dir«7) t& (extr[i*l J.dir«3) ) ) 

If ( <extr[i-l].pen_«ts*extrCi].pen_«ta)--2) 

a*r_x_level«[extr[i].x cor] - TRUE; 
•«_y_laveli[extr[i]*yIcor] - TRUE; 



for <i-e.i<-15:i**) { 

if <arr_x_level»ti>- TROB) < ( ( # f eat ) . f eat[13] ) ; 
if (apr.y_XavaliCi}«TROB) < < (*f «at ) .feet[l4] ) ♦♦) ; 



for (i-e;i<«15 { 9 
arr_x_levela [ i ] -FALSE ; 
arr_y_levele[i]«PALSB| 

for (i»l;i<extrae ,i++) 

if | j(axtr[i].dip«3)IA((axtr[i*l].dip«5) II (extr[i*l] .dir— k) ) ) 

^ <(axtr[i].dip«7)4t((axtr[i*i]-dip--l) || < extr[i* 1] . dir--6) ) ) ) 

if Uextr[i-l].pen • t»*extr[i] . pen »t«)--2) 
<*feat) •fe»c[l5]**; 

' #W / 

for <i»e;i<«15:i") { 

arr_x levels [i]-PALSBi 

arr_jr_levela[i]-MtSB; 
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for (i«l;i<extras;l*«) 



if 



.} 



|(extr[i].dir--l)tt((eKtr[i*l].dir--7) || (extr[i*l ] . dir— 6) ) ) 
i j6xtr[i],dir-.3)t4{(«xtr[i*l].dir«5) || (extr[i*l ] . dir--4) ) ) 

(extr[i).dir--l) (extr[i*l ] .dir-«5) ) II 
'(extr[l].dir--3) " <extr[i*i] .dir--7) ) ) 

if { (extr[i*l] .pen_sts+extr[i] .pan_st«) --2) 

arr_x_levels[extr[i] . x_cor] • TRUE; 
^ arr~y~levela[extr[i] .y_cor] - TRUE; 



for <i-e;i<-15si**) { 

if (arr_x_levele[i]--TRUE) { ( ( # feat ) . f eat[l6] ) ♦♦) ; 
if (err_y_levele[i]--TRUB) ( ( ( *t eat ) . f eat[17] ) ♦♦) ; 



for (i-6;i<-i5;l**) { 
arr x levels[ i ]-FALSE; 
arr~y~levela[i]«FALSB; 

> 

for (i«l;i<extraa:i**) 
if (extr[l].out rot--5) 
{ 

if ( (extr[i-l].pen eta*extr[i] ,pea »t«)-«2) 

{ 

(•feat) .feat[l8]**; 
arr_x_levelf[extr[i].x_cor] - TRUE; 
arr y levela[extr[i] .y cor] • TRUE; 

) 

} 

for (i-e;i<-15;i**) { 

if (arr x_level«[i]«TRUE) ( ( (•feat ) . feat[19] ) ♦♦) ; 
if (arr~y_levela(i]-»TRUE) ( ( ( # feat) .feat[2G] ) ; 

) 



for (i-e;i<-15?i**) ( 
arr x lavela [ 1 ]- PALSE ; 
arr~y~levela[i]-FALSB: 

> 

for (i«l: i<extraa;i**) 

if ( (extr[i].out_rot--3) II < extr[i]. out.ro t««l ) ) 

if ( (•xtrCi-il.pen eta»extr[i] .pan_« t») --2-) 

( 
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(•feat) .feat[21]**; 
arr_x_levela[axtr[i]. x 
arr_y~lavela[axtr[i] ,y] 



cor] - TRUE; 
cor] « TRUE ; 



for (i-0;K-X5;i**) { 

if (arr x leveia[i ]«TRUE) 
if <arr~jr~lavela[i]--TRUE) 



(((Teat).feat[22J)**); 
(((•faat).faatC23])**): 



/ 



calcualtaa the arc features of a ayabol, 
(called froa calc_f eaturea ) . 



void calc.arcs (a true t TABLE EXTREffONS axtr[],int txtrn, 
a tract FEATURES # feat) 

int i«0: 
int J-6s 

while (i<axtraa) 

{ 

if ((«tr[i],in_rot-7) II <extr[i] .io.rofl) ) 
((•feat) .feat[24])*«»; 

whila ((•itr[i].in_rot-7) II (axtr[i] .in_rofl) ) 

} 

i-G; 

while (i<extrae) 

{ 

if <extr[i].in rof-7) 
< 

while <extr[i].in rot-7) {J**;i**;} 
} alaa if (axtr[i].in rof-1) 

{ 

J-i; 

while (extr[i].in_rofl) {J**;i**;} 
{(•faat).faat[25])-(( # faat)-faat[25])*(int)(j/4); 

> 

> 
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calculates the levels features (nuiber of dluffereat levels) of & 
synbol 

(called froa ealc_f eatures ) . 

void calc_ayabol__levels (struct TABLE EXTREMOMS extrf 1 , int extras *' 

struct FEATURES # feat) 



int i»0; 

boolean arr_x_levels[l6] s 
boolean arr~y~levsls(l6] ; 

for (i-e;i<-15;l**) { 
.arr_x_levele[i]-FALSE* 
arr y levels[i]*FALSB; 

) 

for ( i-9j±<»extrs« ;!♦♦) 
{ 

arr_x_levela[extr[i] .x_eor] - TRUE ; 
err_y_levele[sxtr[i].y~cor] - TRUE; 

for (i-0;±<«15:i**) { 

If ( arr_x_levelt [ 1 ] •■TRUE ) < { ( # feat) . f eat[26) ) ) : 
if (arr_y_ieveli[i]«THUB) ( ( (*f eat) . f aet[27 J )♦♦ ) : 



calculates the nuaber of ainuaues/aaxiauas In X and T. 

(called froa calc features). 

void calc_nua_einaax (struct TABLE EXTREMOMS extr[].int extras, 

struct FEATURES # feat) 

< 

int 1; 

for ( i-1 ;i<extras ) 

{ 

if ( (extr[ i-1 ] .pen_sts*axtr[l] .pea_s ts ) «2 ) 

if ( ( (extr[i],dir--5)tt( (extr[i*l].dir--7) || 
(extr[i+l].dlr--6) )) || 
( (extr[i].dlr««3)44( (extr[ i*l ] .dir--l ) | | 
. <extr[i*l].dir«2))) || 

( (extr[i].dir--5) &l (extr[i*l ] .dir--l ) ) || 
( (extr[i),dir--3) fc& (extr[i*l].dir-«7> ) ) 
(•feat) .feat[*7]**: 

if (( (extr[i].dlr"7)4*<(extr[i*l].dlr»5) || 
(extr[i*l).dir«6)) ) || 

( (extr[i]*dir--l)44((extr[i*l].dir— 3) || 
(extr[i*l].dir--2))) || 

( (extr[i].dir--l) fcl (extr[i*l] .dir« 5) ) II 
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( <extr[i].dir«7) 44 (extr[i*l].dir--3))) 

( # r«at).rMtC4S]**! 

if (((extr[i].dir--7)44((extr[i*l].dir— 1) II 
(extr[i*l],dir«G))) || 

( <extr[i].dir--5)44((extr[i*l].dir« 3) 1 1 
(«xtr[t*l].dir--4))) || M 
((extr[i].dir— 5) 44 (extr[i*l].dir--l)) II 
( (extr[i].dir--7) 44 (extr[i*l ] .dlr-»3) ) ) 
(♦feat)*feat[49]**s 

if (( (extr[i].dir—l)44((extr[i*l].dir— 7) II 
<extr[i*l].dir--e) )) || 

( <extr[i].dir--3)44((extr[i*l].dir«5) II 
<extr[i*l].dir«4))) || 

( (extr[i],dir--l) 44 <extr[i*l ] ,dir--5) ) || 
{ (extr[±].dir«3) 44 <oxtr[l+l] .dir»7) ) ) 
(•feat) .feat[56]**s 



/ • •• 

calculates the features of a syabol depending on the extreauas of 
that syabol , and fills in the structure variable: fast, 

void cslc_f aetures (struct FBATUBB3 •feat.lnt points* ' 

struct TABLE EXTREMOMS extr[]» 
l&t extras ,lnt feate) 

{ 

lot 1; 

/• initialization •/ 

for (i-0;i<HUM_PBAT;i**) ( # f «at ) . f aat[i ] -e ; 

(•feet) .feat[9] - feete ; 
{•feat) . feat[l] - points ; 
(•feat) .feet[2] - extras ; 

ealc_spaee_f eat (extr, extras , f sat) ; 
calc_rot (extr , extras , feat) ; 
calc%xt_typea ( extr , extras , feat) ; 
calc~arcs (extr, extras, feet) ; 
calc~syabol_levols (extr .extras , fset) ; 
cale~nua_aiiLaax (extr , extras* feat) : 
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/• This aodul« is for calculating and aenipulatlng «xtrtauis it 
includes four procedures : * 

(1) calc.extreauaa : To find the extreauas of tha ayabol and 
the "change in pen* points. . ana 

(2) find.eax extra : To find the aax/.in X-coordinate and the 
aax/aln Y~coordlnate of tha ayabol. 

(3) analyse_extreeuas : A procedure to analyse the extreauas found 
so far. aainly this procedure aarks close extreauas as 
suspecious extreauas. 

(<*) conv2Ievels : Replaces the actual coordinates of the 

extreauaa in arr_extreauas with the levels of these coordinate, 
by doing quantization, (there are 16 levals). */ 

^include "aaln.h* 

/ 

The input of this procedure is the array of coordinates which holds 
the coordinates of the ayabol , and the nuaber of these points . it 
fills the special of points (i.e. 9 extreauas or change In pen) In 
the array 



arr extreauas 



, it returns the nuaber of special points it found. 



Int calc.extreaoas (struct TAB LB_EXTRBMOMS arr_extreaoee£ ] , 

struct POINT arr_cor[],lnt~nua_of_polnta) 



{ 



unsigned lnt indB; 

unsigned lnt ndx; 

unsigned pen_waa_up; 

lnt crnt_ quart t prev_quart ; 

int crnt~rot.prev_rot; 

int Sx,Sy t PSx,PSy7a*b$ 

lnt f irst_point»l ; 

int Pndx-9; 

unsigned lnt LastNdxt 

lnt 1; 

IndB-e; 

ndx«0; 

pen_was_up«l ; 

3x«0: 

Sy-G; 

PSx*G ; 

PSy*G; 

a-6; b«0 ; 

while (ndx<nua of points) 

( ' 

while ((arr cor[ndx].pen status)«»l) 

( 

if (pen_waa_up--l ) 
{ /* beginning extreaoa */ 
if (first poinfl) 
( 

int tSx.tSy; 
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Sir - ( arr_cor[ndx*l] « x_cor-arr_cor(ndx] -x_cor) ; 
Sy- (arr_cor[ndx*l] .y_cor-arr~cor[ndx J .y~cor) ; 
tSx- (arr_cor[ndx*2] .x_cor-arr_cor[ndx*lJ.x cor) ; 
tSy- (arr_cor[ndx*2] .y_cor-arr_cor[ndx*i] ,y~cor) ; 
a-Sx*tSy-Sy*tSx; " " 

b-Sx*tSx*Sy*tSy; 
PSx-Sx; 
PSy-Sy; 

} 

else { 

/• for the previous ENDING extreaoa •/ 
Sx* ( arr_eor[ndx] . x_eor-arr_cor[Pndx] .x_cor) ; 
Sy" ( arr_cor[ndx] .y_cor-arr_cor[Pndx] .y~cor) ; 
PSx- ( arr_cor[Pndx] .x_cor-arr_cor[Pndx-l] .x_cor) ; 
PSy« ( arr~cor[Pndx] .y_cor-arr2cor[Pndx-l] .y_cor) ; 
a-PSx # Sy-PSy # Sx; " " v " 

b-PSx # Sx*PSy # Sy; 
arr_extreaoaa[iiidB] .p_ndx*Pndx; 
arr~extreaoae[lndB] ,x~cor*arr_cor[Pndx] ,x_cor; 
arr~extreaoas[indB] .y~cor«arr~cor[Pndx].y~cor j 
arr~extreaoaa[indB] .pen_ats-e ; ~" 
arr'ex t reaoas [ IndB ] • dir -de f_quar t ( PSx v PSy ) ; 
arr~extraaoas[ indB] .out rot«def quart (b, a); 
{ 

int PPSx.PPSy; 

PPSx* ( arr_cor[Pndx-l ] . x_cor-arr_cor[Pndx-2] . x_eor) ; 
PPSy-iarr^corCPndx-l] •y_cor-arr2cor£Pndx-2] .y^cor) ; 
a»PPSx # PSy-PPSy # PSx; " ' 

b-PPSx # PSx*PPSy # PSy: 

arr_extreaoa«[indB] . in_rot-def_quart (b t a) ; 



indB**; 
PSx«Sx; 
PSy*Sy; 

{ 

int tSx.tSy; 

Sx« (arr_cor[ndx*l] .x_cor-arr_cor[ndx] .x_eor) ; 
Sy» (arr~eor[ndx*i] .y~cor-arr_cor[ndx] #y_cor) ; 
tSx«(arr_eor[ndx] .x_cor-arr_cor[Pndx] .x.cor) ; 
tSy*(arr3cor[ndx] .y2cor-arr_cor[Pndx] .y_eor) ; 
a«tSx*Sy"tSy # Sx; 
b-tSx # Sx*tSy # Syj 

> 

} 

crnt_quart»def_quart (Sx, Sy) ; 
crnt^rot-def.quart (b,a) 5 

arr_extreaons[indB].p_ndx*ndxs 

arr~extreaoas[lndB] .x_cor*arr_cor[ndx] .x_eor; 

arr~extreaoaa[indE] .y~cor«arr3cor[ndx] .y_cor ; 

arr~extreaoas(indB].pen_sta«l; 

if If irst_point"l) { 

arr_extreaoas[indE] .dir-15 ; 
arr~extreaoas[ IndB] . in_ro t- 15 S 
arr~ex t reaoas [ indB] • out_ro t"15 ; 
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ndx** ; 

first point-0; 

} 

else { 

arr_extrenoos[indE] . dir-def_quar t (PSx, PSy} ; 
arr_extremoas[ indE] . in_rot»Q; 

arr_extreaoas[indE].out_rot-def_quart(b t a) ; 

indE**; 
pen_was_up»0 ; 
> else ( 

crnt_quart«def_quart (Sx.Sy) ; 

crnt_rot-def_quart(b.a) ; 

if (( (crnt_quart f «prev quart) || 
((crnt_rot>-*) && (prev_rot<4 ) ) || 
( (crnt_rot<4) LL (prev_rot>«4) ) 

tt (prev_rott-15) ) 

{ /* regular extreaoa */ 
if ((abs(Sx)>G) LL (abs(Sy)>0) || (b<0) ) 

if ( (ndx-l-arr_extreaoaa[indE-l] ,p_ndx) >G) 

arr_extreaoas[indE] .p_ndx*ndx-l ; 
arr_extreaoaa[indE].x~eor-arr_cor[ndx-l] .x cor; 
arr_extreaoas[indE] . y_cor-arr~cor[ndx-l ] ,y~cor ; 
arr_extreaoas[indE] .pen_sts»l~ 
ar r_ex treaoas [ indE ] . dir-prev_quart ; 
arr_extreaoas[indE] . in_ro t-prev rot; 
arr_extreaoaa[lndE] . out_rot«crnt_rot ; 
indE++; 

} 

} 

} 

} 

ndx**; 

Sx»( arr_cor[ndx] .x_cor-arr_cor[ndx-l ] .x_cor) : 
Sy» ( err_cor[ndx] .y_cor-arr_cor[ ndx-1 ] .y^cor) ; 
a"PSx # Sy-PSy*Sx; " ~ 

b-PSx # Sx«>PSy # Sy ; 
PSx«Sx; 
PSy-Sy ; 

prev^quart*crnt_quart ; 
prev~rot«crnt_rot ; 
) /* end of while ( arr_cor[ndx] .pens tatus*«l ) •/ 
if ( (pen_was_up-"0) ( arr_cor[ndx-l ] ,pen_s tatus**l ) ) 
{ /• ending extreaoa */ "~ 
Pndx«ndx-1 ; 
pen_was_up«l ; 
Las tNdx«ndx-l ; 

} 

ndx** ; 

> /• ndx<-NuaOfPoints •/ 
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/• Add the last special point to the array •/ 

arr_extreeoaa[indE].p ndx»LastNdx 5 

arr_extreaoas[indE].xZcor«arr corfLaa tNdx] . x cor* 

arr.extro«o«a[±ndB].y^cor.arr_cor[LaatHdx].y"cori 
arr_extreaoaa[in<*E].p«n ats-0; 

Sx-(arr.cor[LaatNdx-l] .^cor-arr.cor[LaatKdx-2] # x cor) « 
Sy- { arr_cor [ Laa tKdx-1 ] . x_cor-arr_cor[ Laa tNdx-2 ] x"cor \ 
PSx- arr.cor[LaatNdx.2].x_cor-arr.cortLa.tMdx-3].J III • 
PSy-(arr„corCLa.tNdx.2]. y- cor-arr:cor[La.tHdx-3J y"c« • 
arr_extreaoae[indE] .dir-def quartJSx.Sy) ; -y.cor ) . 

a-PSx»Sy-PSy # Sx; " W9 % 

b-PSx*Sx*PSy # Sy; 

arr_extreBoaa[indE].in rofdef quart(b.a): 
arr_extreaoa«[indEJ .out_rot«157 

return (IndB); 



♦ 

void find_nax_extra (struct TABLE BXTRBNONS arr extreeoasM 

lnt nua.of .extras. lot *Xaln.lnt *Xaax. ' 
iat •Yaia.int *Yaax) 

unsigned lnt 1*0 1 

•Xain-1296; 
*Xaax*0; 
•Yain-1200; 
# Yaex*0; 

while (i<-aua_of .extra* ) 

if (arr_extreeoee[i].x_cor<^Xain) •Xain-arr_extreao.a[i].x cor; 
if arr_extreaoas[i].x_cor>»Xaax) «Xaax-arr extreaoea[i] .x"cor: 



} 



; is" — A««K-irr_fxcrfiouLl I .X cor; 

if arr.ext rtiois [ i ] . y_cor < •Ttin ) *Yaln«arr extreaoae[ i ] . y~eor: 
if (arr.extraaoaiCl].y.cor>*Yaax) •Yasx«err"extreeooaU ] .y~eor; 
l ♦ ♦ i • 



) 



correct dir f in_rot>out_rot for auaplclous points . called froa 
aoalyse_extreauas 

void correct.extra (struct POINT err eor[]. 

Struct TABLB^BXTRBNOHS extre[]. 

struct TABLB.BXTRENONS arr exc extraM , 

lnt i.int Pi.lat J) "J 

lnt Sx.Sy , PSx.PSy; 
lnt ndxl.ndx2; 
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Int a.b; 

ndxl»extrm[ Pi ] . p_ndx; 
ndx2 s extra[l]. p_ndx ; 
if (Pi>0) 
{ 

if (extrn(Pi-l] .pen sts«-0) 

{ 

PSx"arr_eor[ndxl] . x_cor-arr_cor[extra[Pi 
PSy«arr_cor[ndxl] .y_cor-arr_cor[extra[Pi 

else { 

PSx»arr_cor[ndxl ] . x_cor-arr_cor[ ndxl 
PSy-arr_cor[ndxl ] .y2eor-arr_cor[ndxl 

} else {PSx-O: PSy-9; } 

Sx»arr_cor[ndx2] .x_cor-arr_cor[ndxl ] .x_cor; 
Sy«err_cor[ndx2] .y3cor-arr~cor[ndxl] .y_cor: 
a»PSx*Sy-PSy*Sx j ~ ~ 

b«PSx*Sx*PSy # Sy; 

if ( arr_exc_extra[ J-l] .out^rot I -15 ) 

arr_exc_extra[ j*l]«out_rot-def_quart(b t a) ; 

PSx«Sx; 
PSy«Sy ; 

arr_exc_extra[ J] .dir"def_quart(PSx,PSy ) ; 
arr_exc_extra[ J ] • in_rot»9 ; 
if (arr axe extra[ j ] . out rotl-15) 
( 

if (extra[i].pen ata-«G) 

{ 

Sx«arr_cor[extre[i*l ] .p_ndx] . x_cor-arr_eor[ndx2] .x_cor; 
Sy*ar r^eor (ex tra[ i ♦ 1 ] . p~ndx ] . y~cor-arr~cor(ndx2 ] . y~cor ; 

else 

( 

Sx»arr_cor[ndx2*l ] .x_cor-arr_cor[ndx2] .x_cor; 
Sy-arr~cor[ndx2*l ] . y"cor-arr~cor[ndx2 ] .y cor; 

} 

a«PSx*Sy-PSy*Sx: 
b«PSx # Sx*PSy # Sy; 

arr axe extra[J].out rot-dof quert(b,a); 
) ~ 

} 

/ 

A procedure to analyse the extreauas found ao far , aalnly this 
procedure aaxka close extreauas as suapecioua extreiuis. 

* ** *•/ 
int analyse extreaoae (struct POINT arr cor[], 

struct TABLE EXTREKONS extra[] v 

struct TAB LE^EXTR EMOMS arr_exc_extra[ ] . 

Int nua of extras) 

( 

int i,j-9; 
int count-0; 



i]-P.ndx] .x_cor; 
1 ] * P_ndx] . y_cor ; 



- 1 ] . x_cor ; 
-l],y~cor; 
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boolean FirstP»TRUE; 




. u- 1] 

(extrn[i].pen_sts"l) && 
(extra[i-l]. P en_sts!-0) ) extrm[i] .susp-1 • 
else {extrn[i].susp'Oicount**;} ' 

extrn[0] .susp-G; 
extrm[ i j . susp"G ; 
/•count** ; */ 

for (i»0;i<-nun_of_extriiflii**) 

If (extrn[i] ,susp--G) { 

arr_exc_extrm[J] . P _ndx-extrm[i3.p ndx- 
arr_exc_extrm[ j ] .x_cop-extrB[i].x"cor; 
arr_exc_extrm[ j ] .y_cor-extrm[i] .y"cor; 
arr_exc_extrm[ j ] .pen_sts-extr»[l]Tpen sts; 
apr_exc_extra[J] .dlr-extrn[l].dir: 
arr_exc_extrm[j].±n_rot -extrm[ i] . in rot; 

f * r T»? C - extr8lC J 3 ' ou t-«t.extr«i[i ] . out rot ; 
if (FirstP- -FALSE) 

correct_extrm (arr_cor . extro , 
arr_exc_extpa,i t Pi,j) ; 
FirstP-TRUE; 

} 

if (extrm[i] .pen_sts--0) FirstP-TRUE: 

} 

else { 

if (FirstP) Pi-i-i; 
FirstP-FALSE; 

} 

} 
{ 

/♦FILE •fp; 

fp-fopen ( "extro .out" , "ab*") ; 
for (i-0:i<-count;i**) 

fprintf (fp,"Xd %& %d %d JSd %d %d \n". 
arr_exc_extrm[i] -p_ndx,arr_exc extrm[i] .x_cor, 
arr_exc_extrn[i] . y _cor,arr_excIextrm[i] .pen sts 
arr_exc_extrm[i].dir.arr exc_extrn[i] . in rot. 
arr_exe_extrm[i] ,out_rot) ; 

fprintf (fp."*» 

fclose (fp) ;•/ \» J : 
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} 

return (count) ; 

} 

/ 

Replaces the actual coordinates of the extreauas in arr extreau 
with the levels of these coordinates by doing quantization . ( the 
16 levels). it also calculates featO : i.e. the relative size of 
syabol«32*div round (Xwidth , Ywidth) . 



void conv21evels (struct TA8LE_EXTREM0MS arr extreaoas(], 
int nui or extras, int *featOl 

{ 

int. x_width.y_width: 
int Xain ,Xaax,Yaln» Yaaxs 
int i-Ot 

flnd_aax_extra ( arr_extreaoaa , nua_of_extras • LXain, 4Xaax f 4Yain. tYsax) ; 
x width»Xaax-Xain ; 
ylwidth-Yaax- Yain t 

while <i<»nua of extras) 

{ " " 

arr extreaoaa [i] .x cor*div round ((arr extreaoas[i] .x cor- 

Xain) # aRID,x_width) ; 
arr extreaoas[i] ,y_cor-div round ((arr extreaoae[i] .y cor- 

Yain) # GRID,y_width) : 

) 

(*feate)-dlv round (56*x width. y width); 

} 



SUBSTITUTE SHEET 



91 - 



^include "aain.h" 

void print_features (struct FEATURES # feat,char filenaae[]) 

FILE »fp; 
int i; 

fp-fopen ( filename, "ab* n ) ; 

/•fprintf (fp."name of symbol -XsNn" . ( # feat) . IDf eat ) ; 
fprintf (fp."si*e of symbol -Xd\n" , ( # f eat ) - featO) ; 
fprintf (fp, "number of points -Xd\n" # ( # feat ) • featl ) ; 
fprintf (fp. "number of str -*d\n" , ( *feat ) . f eat2) ; 
fprintf (fp. "number of spaces -Jtd\n" , ( # feat) . feat3) ; 
fprintf (fp. "number of diff. levels in X for end of 

space-Sd\n". ( # feat> • feat**) ; 
fprintf (fp, "number of diff. levels in V for end of 

space»Xd\n ,, t ( # f eat) .featS) ; 
fprintf (fp. "number of apaces for q<U «*d\n", (*feat) .feat6) ; 
fprintf (fp, "number of spaces for q>-4 -Xd\n" , ( # feat) • f eat8) ; 
fprintf (fp, "number of spaces ro<** 

•*d\n" f (Teat) .feat73>5 
fprintf (fp, "number of spaces ro>-4 

•*d\n", ( # feat) .feat75): 

fprintf (fp, "number of linear strokes 

•Xd\n" , ( # feat) . featlG) ; 
fprintf (fp. "number of linear strokes where dir<4 

-%d\n" . ( # feat) .feat69) : 
fprintf (fp ."number of linear strokes where dlr>«4 

-Xd\n" . ( # feat) .feat7D ; 

fprintf (fp. "number of strokes with pos .rot 

•*d\n" . ( # feat) . featll) ; 
fprintf (fp. "number of strokes with neg. rot 

-Xd\n" . ( # feat) • featl2) ; 

fprintf (fp, "number of strokes ro<4 

-*d\n",( # feat) .feat!3) ; 
fprintf (fp, "number of strokes ro>-^ 

-Xd\n" ( ( # feat).featl5); 

fprintf (f p. "number of Ext in X neg. rot. 

-3Cd\n" . ( # feat) . feat!7) ; 
fprintf (fp,"diff. levels in X for minX 
fprintf (fp/"diff. levels in Y for minX 

fprintf (fp, "number of Ext in X pos. rot. 
fprintf (fp,"diff. levels in X for aaxX 
fprintf (fp."diff. levels in Y for maxX 

fprintf (fp, "number of Ext in Y neg. rot. 
fprintf (fp,"diff. levels in X for minY 
fprintf (fp,"diff. levels in Y for minY 

fprintf (fp. "number of Ext in Y pos. rot. 



-Zd\n" t ( # feat) . f eatl8) ; 
• *d\n" , ( # feat) . featl9) : 

•*d\n" , (*feat) . feat20) : 
-*d\n", ( # feat) . feat2i) ; 
«Xd\n", ( # feat) .feat22) ; 

-Xd\n". ( # feat) .feat29) : 
•*d\n"*( # feet).feat30) ; 
-Xd\n", ( # feat) .feat3D • 

-Xd\n". ( # feat) .feat32) ; 
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fprincf (fp.-diff. levels in X for maxY -td\n - . ( • f eat ) . f ea 1 33 J • 
fprintr (fp.'diff. levels in Y for oaxY -Xd\n" . ( »f eat) . f ea t3* ) i 

fprintf (fp/nuaber of ext XY for neg. rot-Sd\n" t ( # f eat) . feat*»l ) • 
fprintf {fp, "different levels in X for ext XY-neg.rot 

*%d\n n . ( # feat) .feat*J2) ; 
fprintf (fp, "different levels in Y for ext XY-neg.rot 

•*d\n". (*feat) .feat<«3) ; 

fprintf (fp t fl nuober of ext XY for pos. rot 

„ , -Xd\n". ( # feat) .feat44) ; 

fprintf ( fp, "different levels in X for ext XY-pos.rot 

m t •*d\n". ( # feat) .feat^S) ; 

fprintf {fp, "different levels in Y for ext XY-pos.rot 

•*d\n* t («feat).feat46); 

fprintf (fp."nuBber of arc parts ■Xd\n" , ( *f eat) . f eat65) ; 

fprintf (fp,"nuaber of circle parts -Jtd\n" , ( # f eat) . f eat66) ; 

fprintf (fp. -number of different X-levels -Xd\n" , (*feat) .feat67) ; 

fprintf (fp, "number of different Y-levels -*d\n" , { *f eat ) . f eat68 ) ; 

fprintf (fp,"sum of square weights 

-%d\n w t ( # feat) . sum_sqr_wgt ) ;•/ 

fprintf (fp, w \nSs\n w , ( # feat) .IDfeat) ; 
for U-Q;i<NUM FEAT; i** ) 

{ 

fprintf (fp."*3d*. ( # feat) .feat[i]) ; 

if ((i--20) || (i--U0)) fprintf (fp."\n*); 

} 

f close ( fp) ; 
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^include "aain.h" 

int transform(char infile[30] , atruct FEATURES Veat) 



Struct POINT arr_cor[MAX_NUM_OF_POINTS]; /• array of coordinate. •/ 
atruct TABLE.EXTREMOMS arr_ex t reoons [MAX NUM OF EXTREMOMS 1- 

/• array of special points (i.e. extre"«n«^ ."chansin* of pen 

position f 

struct TAB LE_ EXTREMOMS arr_exc_ex tras [MAX NUM OF EXTREMOMS 1 
/• array of excluded extreauas . it is ex*ciu"ded from tt 
of extreauas by excluding close points •/ 



the array 



int featO; 

lnt nua_of.pointa t nua.of_extras, exc_nua_extras ; 



/ 

Reading; a file and calculate the nuaber of points for the syabol.and 
stores the points read in the array : arr cor . 



ly : arr_cor 

_ _ . _ _ i 

if (nua.of_pointa«0) return (0); 



nua.of.points-read.points ( arr_cor, inf lie) ; ' 



I # . # 

Calculatea the extreauas froa the array of coordinates . and stores 
it in the array : arr_extreauas . the function returns the nuiber of 
"•"5*"*ii,SSi5!ii"5j # ; # and **' is st ° r «d m nua.of.extras. 
auB.of.extrMa-calc.extreaoaa (err.extreaoas . irr.cor .nua.of.pointe) ; ' 

I • 

Replaces the actual coordlnatea of the extreauas in arr extreauas 
with the levels of these coordinates by doing quantisation, (there 
are lb lave La ) 

conv21evela ( arr_extreaoas.nua.of. extras ,4feat0 ) ; ' 

/ . 

Excludes close points in the extreauas array and stores the reaalnlns 
extreauaa in arr.exc.extraa f it returns the nuaber of extreauas left 
after excluding*. 



ing*. 

*""*•*****•***••••*•**♦•*•*••*•••••••••♦♦*•♦•••••••••••••••••#•• •/ 

e_nuB_extras*analyse_extreaoas (arr cor.arr extreaoas. 
arr.exc_extraa.nua of extras); 



/ 

calculatea the features of the syabol . and stores it in the structure 
variable feat*. - 

ealc. features 

(&( # feat) »nua_of .points , arr_exc_ex tras , exc_nua_extraa » f eatO) ; 
return (nua of points); 
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0 include "aain.h" 

/•••••••••• • 

a function which recieves as input the features of a symbol and 
maximum and minimum features . and returns the estimation of the 
features' entered symbol is the symbol with the min and .ax 

int rec (struct FEATURES feat. struct FEATURES min feat * ###/ 
struct FEATURES max_feat) 



int D; 
int theta; 
int W; 

unsigned long temp«0; 
unsigned long aum_w«9; 
int tempi; ~ 
int N-0; 
int Rv; 
int 1; 

for ( i"0 : 1<NUM_FEAT; i** ) 

if ( (feat.feat[i]<-max feat. f eat[i]) 14 
(feat . featfi ]>-ain_f eat. feat[i]) ) 
theta-G; 

else { theta-l;N**; } 
If ( (■in_feat.feat[l]*aax_feat.feat[lJ)-«0) 

W-o j 

D-32 # feat.feat[i]-i6i 

else 

{ 

D-abs(dlv_round(32 # f«at. f aat[l] ,ain_f eat . feat [!]♦ 

■ax~feat.feat[i])~l6) ; 
tf«div_round(32 # ain_faat.faat[i] f «in_feat.feat[l]*aax_feat.feat[i]) ; 

ir ((W--16) && (theta— 1)) theta-8; 
teap*«(D*theta) ; 
sua w*-W; 

} 

tempi - ( int) 190* teap/sua w; 

Rv - div_round ( (NUH_FEAT-R ) • ( 100-templ ) ,NUM_FEAT) ; 
return max (0,Rv); 
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/• Default values 
#define NJ>OINT 
#define DIMENSION 
fdeflne N CENTER 
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APPENDIX 0 

•/ 

500 // Number of points 

3 // Number of dimentions 

4 // Number of eentroids 
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^include "starch" 
# include < graphics . h> 
^include <stdlib.h> 
^include <stdio.h> 
# include <conlo. h> 
finclude <math.h> 

int prepare (int xc[][].int # al.int *a2,int *m3.int # m<l); 
void aelect_beg (int cntr[ ][ ] , int al.int n2,int n3,int bU) 
float distance (int xc[],int cntr[]); 
float sum dlst (int cntr[][],lnt x[]); 



/• Main prograa for clustering */ 

void main ( ) 
{ 

int x[N P0INT][DIMENSI0N], 11.12. 13. nua points. 14; 
int center[N CENTER] [DIMENSION] , prev cntr[ DIMENSION] t 

new_cntr[DIMENS ON] ; 
int erroreode:" 
int aax_x.«ax_y # ain_x t ain_y ; 
long sua_def-0; 

float cur_dist»0. weight [N_P0INT] . eoaa_weight.dist»0; 

/• Initialization of coordinates of all the points */ 

for (il-0;il<N POINTjil**) 

for (i2-0;i2<DIMENSI0N;i2**) ( 
x[ilHi2]-0; 

nun_points - prepare (x t iBin_x, 4aax_x, iain_y ,4aax_y) ; 
aelect_beg( center ,ain_x , aax_x. ain_y ♦nax_y) ; 



/* Calculating for every centroid it's new position according 
it's prevlos position and it's distance froa all the points. 

V 

for (il-0;il<N CENTER ; 11 ) { 
for U2-0;i2<DIMENSI0N;i2**) ( 
new_cntr[i2] - 0; 
prev cntr[i2]-center[il][i2] ; 

) 

/* Calculating the aeabership value of each point to the current 
centroid */ 

for (13-O.coaa weight-© ; i3 <nua_points : 13** ) { 

if ((cur diat-distance (ix[13][0] . tcenter[il] [0] ) ) <0.0001) 

weight[i3]-l-0; 
else 

weigh t[i3]-( l/cur_dist)/§uB_dist (center. 4x[i3][0]) : 
coaa weight weigh t[ 13 ]* weigh t[ i3 ] ; 
far Ti**-0;i4<DIMENSI0N;i4»*) 

new cntr[i4]*- weight[ 13 J'weightCiSJ^xCiSlCi^] i 

} 
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/• Calculation of the new position of the centroid •/ 

for (i4-0; i4<DIM£NSI0N;iH*o) { 
new_cntr[i4]/»coBB_weight ; 
center[il][i4] - new_cncr[i<* ] ; 



/• Checks the movement of the current centroid and stops the 
iterations if it is small (less then 3). 

if (il--N_CENTER-l) { 

if ( (dist*«distance(prev_cntr.4center[il][0]) )<3) 

break; 

dist - 0; 

il»-l; 

} 

else { 

dist*- distance (prev_entr, &center[il ][0] ) ; 



/• Printing the points and the centroids •/ 

for (il-0;il<num points;il*+) { 

printf ("\n Point f t& : "»il); 

for (i2-G;i2<DIMENSI0N;i2**) 
^ printf (" J5d ".x[il][i2]); 

printf ("\n\n\n\n") ; 

for (il«0;il<N CENTER; il** ) { 

printf ("\n CENTER # %& : ".il); 

for (i2-G;i2<DIMENSI0N;i2**) 

printf <" %5& 9 .center[il][i2]) ; 

> 

getch {); 
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' #include "starch" 
/• This procedure selects the initial sec of centroids */ 

void select_be S (int cntr[N_C ENTER] [ DIMENSION J . int min x 

int aax_x,int min_y,int oax_y) ~ ' 

cntr[0][0]--10G; 

cntr[0][l]--10G; 

cntr[0][2]-100; 

cntr[l][0]-200; 

cntr[l]Cl]-0; 

cntr[l]C2]-30Q; 

cntr[2][O]-0; 

cntr[2][l]--l50; 

cntr[2][2]-^GG; 

cntrCSKOJ-'JGG; 

cntr[3][l]-i»GG; 
cntr[3][l]-5G; 
/* cntr[O][4]»0; 

cntr[l][0]-2 # max_x; 

cntr[l][l]-2 # min_y; 

cntr[l][2]-2G0: 

cntr[l][3]-lOO; 

cntr[l][*f ]-10; 

cntr[2][G]-max x; 

cntr[2][l]«aax~y; 

cntr[2][2]-10G; 

cntr[2]C3]-lGO; 

cntr[2][4]-20; 

cntr[3][0]»min x; 

cntr[3][l]-max""y ; 

cntr[3][2]"3QGT 

cntr[3]C33-lG0; 

cntr[3][4]-30; 
cntr[t»][0]-min_x/3 . 

cntr[it][l]-Bin_y/3; 
cntr[4][2]-2Q0; 
cntr[lf][3]-lGG; 
cntr[4][i»]-0; 

cntr[5][G]-max_x/3; 

cntr[5][l]-ain_y/3; 

cntr[5][2]-2GQ; 

cntr[5][3]-10G; 

cntr[5][4]-10; 

cntr[6][0]-max x/3; 

cntr[6][l]-maxIy/3: 

cntr[6][2]-lGO; 

cntr[6][3]»lQ0; 

cntr[6][4]-2G; 

cntr[7][G]-min x/3; 

cntr[7][l]-niaxIy/3; 
cntr[7][2]-3GG; 
cntr[7][3]-10G; 
cntr[7][U]-3Q; 
cntr[8][G]-min x # 2/3; 
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cntr[8][l]-min y # 2/3; 

cntr[8][2]-2007 

cntr[8][3]-iGO: 

cntr[8][4]-0; 

cntr[9 J[0]-max_x # 2/3 ; 

cntr[9Kl]-min_y*2/3; 

cntr[9K2]-2G0; 

cntr[9][3]-100; 

cntrC9]C 1 »]-lG; 

cntr[10][O]-max_x*2/3 5 

cntr[10][l]-max y # 2/3 } 
cntrCl0][2]-100T 
cntrClO][3>100; 
cntr[lO][i»]«20; 
cntr[H][0]-min x*2/3: 
cntr[ll][l]-Bax y # 2/3s 
cntr[ll][2]-3O0T 
cntr[ll][3]-iG0. 
cntrCll][^]«30; •/ 
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#include "start. h" 

^include <tlae.h> 

^include <stdlib.h> 

^include <stdio.h> 



/ # This procedure gets the points froa file or froo other input 
device and calculates the aaxiauas and ainlauas for each 
diaention (two diaentions in this exaaple •/ 

int prepareUnt xc [N_P0INT] [ DIMENSION] t int # ain x.int # aax x, 

int *ain y.int *aax y} " " 

{ " 

int count 1 , count 2 ; 

FILE • fp; 

•aax_x ■ -10000; 

•aax^y ■ -10000; 

•ain^x ■ 10000; 

*ain_y - 10000; 

f p«f open ( "strokes •stc" • "r") ; 
countl ■ 0; 

while ( fscanf < f p , "Z6d%6dX6dX6dX6d%6d\n* .lcount2. 

*xe [ countl ][0] .4xc[countl][l] .txc[ count 1][2] . 

lxc[countl][3] .txc[countl][4]) > 0) { 
/• xc[countl][0]*-100; 

xc[countl][l]*-ieO; # / 

# aax_x ■ aax( # aax_x ,xc[countl ][G] ) ; 

•»ax_y • aax(*aax~y,xc[coui*tl][l]) ; 

*min_x - ain( *ain2x,xc[countl][G] ) ; 

•ain^y ■ n±n(*»in~y ,xc[ countl ][1] ) ; 

countl**; 

} 

fclose (fp) ; 
return countl; 
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^include <aath.h> 
^include "start. h" 

/♦ This function gets two points and returns the sqr of the 

distance between this points e ,j 

float distance (int pointl[DIMENSION] .int POint2[DIHENSI0N] ) 

int i_c; 
float~8ua; 

for (i_c-0,sua>-O.G;i_c<DIHENSION{i c**) 

8u-*-((float)(pointl[i_c].point2ri_c]J)«((flo.t)(pointlCi.c]- 
return sua ; ~ 

> 
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#inelude "start. h" »«,-rii. 
float distance (±nt pnt[].int cntr[J). 

/• Thi« function gats a point and the positions of all centrolds 
7 .2J p^Srns of aqr distance, bet— n this point and 

all the centroida •/■ 

* int ie_l.±e_2| 
float cur.dist; 
float eoa cur-0; 

for (1c l-e:ic 1<N CENTER; ic.W) { np ^, % 
cur kat-dietan«(pointatcntr[lc_l][e]); 

if Tcur^diat <.eeoi) 

cur diet • 10066.; 
aua~cur le/cur_diat; 

} 

return «ua_cur; 
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1 CLAIMS 
2 

3 1. Apparatus for reading handwriting comprising: 

4 a sensor for sensing features of handwriting 

5 of an individual which features are highly 

6 characteristic of the individual but which also contain 

7 information relating to symbols being written; and 

8 circuitry, which is configured for the 

9 individual, for providing a non- individual dependent 

10 output indicating the symbols being written in response 

11 to the sensed features. 
12 

13 2. Apparatus according to claim 1 and wherein 

14 said sensor and said circuitry are contained in a hand- 

15 held housing. 
16 

17 3* Apparatus according to claim 1 and also 

18 comprising a transmitter for wireless communication 

19 with a computer to which said transmitter inputs 

20 symbol data. 
21 

22 4. Apparatus according to claim 1 and wherein 

23 said non-individual dependent output is suitable for 

24 communication with the keyboard input of a computer. 
25 

26 5* Apparatus for reading handwriting comprising: 

27 personalized hand-held apparatus for sensing 

28 acceleration during handwriting and providing an output 

29 indication of handwriting content in a- non-personalized 

30 form. 
31 

32 6. Apparatus according to claim 5 and also 

33 comprising a transmitter for wireless communication 

34 with a computer to which said transmitter inputs said 

35 output indication. 
36 

37 7. Apparatus according to claim 6 and wherein 

38 said output indication is suitable for communication 
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1 with the keyboard input of a computer. 
2 

3 8. Apparatus for reading handwriting comprising: 

4 wireless hand-held apparatus for sensing 

5 handwriting and providing an output indication of the 

6 contents thereof. 
7 

8 9* Apparatus according to claim 8 and wherein 

9 said hand-held apparatus senses acceleration during 
10 handwriting, 

11 

12 10. Apparatus according to claim 8 and wherein 

13 said apparatus is trainable. 

ih 

15 11- Apparatus for reading handwriting comprising: 
16 

17 personally trainable hand-held apparatus for 

18 sensing motion during handwriting and providing an 

19 output* indication of handwriting content. 
20 

21 12. Apparatus according to claim 11 and wherein 

22 said hand-held apparatus senses acceleration. 

23 13. Apparatus according to claim 11 and also 
comprising a transmitter for wireless communication 

25 with a computer to which said transmitter inputs 

26 symbol data. 
27 

28 14. Apparatus according to claim 11 and wherein 

29 said non-output indication is suitable for 

30 communication with the keyboard input of a computer. 

31 . 

32 15- Apparatus for reading handwriting in real 

33 time comprising: 

34 a hand held housing; 

35 a motion sensor disposed in said housing; 

36 a plurality of parallel recognizers disposed 

37 within said hosing and receiving signals from said 

38 motion sensor for sensing a plurality of handwriting 
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1 characteristics; and 

2 symbol recognizing means disposed in said 

3 housing receiving the outputs of said plurality of 

4 parallel recognizers for providing an indication of a 

5 handwritten signal. 
6 

7 16. Apparatus according to claim 15 and wherein 

8 said motion sensor is operative to sense acceleration. 
9 

10 17 . Apparatus according to claim 15 and also 

11 comprising a transmitter for wireless communication 

12 with a computer to which said transmitter inputs 

13 symbol data* 
14 

15 18. Apparatus according to claim 1 and wherein 

16 said indication is suitable for communication with the 

17 keyboard input of a computer. 
18 

19 19. Apparatus for reading handwriting comprising: 

20 hand-held apparatus for sensing motion during 

21 handwriting and providing an output indication of 

22 handwriting content in a form corresponding. to that of 

23 a conventional keyboard, 
24. 

25 20. Apparatus for reading handwriting comprising: 

26 hand-held apparatus for sensing motion during 

27 handwriting and providing an output indication of 

28 handwriting content in a RS-232 compatible form. 
29 

30 21. Audio-visual apparatus including apparatus- 

31 for providing a human sensible output including 

32 information in at least one of audio and visual form 

33 and having as an input element hand-held apparatus for 

34 sensing motion during handwriting. 
35 

36 22. Audio-visual apparatus according to claim 21 

37 and wherein said hand-held apparatus comprises: 

38 a sensor for sensing features of handwriting 
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1 of an individual which features are * highly 

2 characteristic of the individual but which also contain 

3 information relating to symbols being written; and 

k circuitry, which is configured for the 

5 individual, for providing a non-individual dependent 

6 output indicating the symbols being written in response 

7 to the sensed features. 
8 

9 23. Portable information storage and retrieval 

10 apparatus including a portable computer memory and 

11 output device and having as an input element hand-held 

12 apparatus for sensing motion during handwriting. 
13 

14 24. Apparatus according to claim 23 and wherein 

15 said hand-held apparatus comprises: 

16 a sensor for sensing features of handwriting 

17 of an individual which features are highly 

18 characteristic of the individual but which also contain 

19 information relating to symbols being written; and 

20 circuitry, which is configured for the 

21 individual, for providing a non- individual dependent 

22 output indicating the symbols being written in response 

23 to the sensed features. 
2k 

25 25. Lock apparatus including locking apparatus 

26 responsive to a predetermined electronic input and 

27 having as an input element hand-held apparatus for 

28 sensing motion during handwriting. 
29 

30 26. Apparatus according to claim 25 and wherein 

31 said hand-held apparatus comprises: 

32 a sensor for sensing features of handwriting 

33 of an individual which features are highly 

34 characteristic of the individual but which also contain 

35 information relating to symbols being written; and 

36 circuitry, which is configured for the 

37 individual. for providing a non-individual dependent 

38 output indicating the symbols being written in response 
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1 to the sensed features. 
2 

3 27. Magnetic card activated apparatus including 

4 apparatus for reading a magnetic card and having as a 

5 verification input element, hand-held apparatus for 

6 sensing motion during handwriting. 
7 

8 28. Apparatus according to claim 27 and wherein 

9 said hand-held apparatus comprises: 

10 a sensor for sensing features of handwriting 

11 of an individual which features are highly 

12 characteristic of the individual but which also contain 

13 information relating to symbols being written; and 

1^ circuitry, which is configured for the 

15 individual, for providing a non-individual dependent 

16 output indicating the symbols being written in response 

17 to the sensed features. 
18 

19 
20 
21 
22 
23 
2H 
25 
26 
27 
28 
29 
30 

31 
32 

33 
34 
35 
36 
37 
38 
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